質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

4回答

2854閲覧

何度も伺って済みません、試行錯誤してますがDELETE文が結果を出せないので教えてください

kenjikobayashin

総合スコア31

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

0クリップ

投稿2014/12/18 07:47

質問を再編集させていただきます以前から質問させていただいてる件ですが、エラーコードの設定が出来なく分かりにくいのですがどうか教えてください。
以下の内容でPHPとMySQLを利用してHP上からのDB内の登録レコードを削除しようとしましたが、最後のif($flag){の結果がelseになってしまいますどうか教えていただけませんでしょうかお願いいたします。
DBには。primary、auto_incrementに設定したcode、全角文字8字以内の名前staff_namae、md5方式で暗号化された半角英数字32字のパスワードがstaff_passに入っています。
SQL文以外が同じ内容でUPDATE文では成功いたしておりますので、DELETE文に問題があると思いますがそれが何かが分からないのでなにとぞお願いいたします。
DB構造
mysql> show fields from mst_staff;
+-------------+-------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+-------------+-------------+------+-----+---------+----------------+
| code | int(11) | NO | PRI | NULL | auto_increment |
| staff_namae | varchar(16) | NO | | NULL | |
| staff_pass | varchar(32) | NO | | NULL | |
+-------------+-------------+------+-----+---------+----------------+
一覧
$dsn='mysql:dbname=shopdb;host=localhost';
$user='root';
$password='';
$dbh=new PDO($dsn,$user,$password);
$dbh->query('SETNAMES utf8');

$sql = 'SELECT code,staff_namae FROM mst_staff WHERE 1'; $stmt=$dbh->prepare($sql); $stmt->execute(); $dbh = null; print 'スタッフ一覧<br /><br />'; print '<form method="post" action="staff_branch.php">'; while(true) { $rec = $stmt->fetch(PDO::FETCH_ASSOC); if($rec==false) { break; } print '<input type="radio" name="staffcode" value="'.$rec['code'].'">'; print $rec['staff_namae']; print '</br>'; } print '</br>'; print '<input type="submit" name="edit" value="修正">'; print '<input type="submit" name="delete" value="削除">';

見えないページ"staff_branch.php"で修正と削除の処理をを分岐させて

<?php if(isset($_POST['edit'])==true) { if(isset($_POST['staffcode'])==false) { header('Location:staff_ng.php'); } $staff_code=$_POST['staffcode']; header('Location:staff_edit.php?staffcode='.$staff_code); } if(isset($_POST['delete'])==true) { if(isset($_POST['staffcode'])==false) { header('Location:staff_ng.php'); } $staff_code=$_POST['staffcode']; header('Location:staff_delete.php?staffcode='.$staff_code); } ?>

削除確認

<body> <div id="contents"> <?php

try
{

if (isset($_GET["staffcode"])) {
$staff_code= $_GET['staffcode'];
}

$dsn='mysql:dbname=shopdb;host=localhost';
$user='root';
$password='';
$dbh=new PDO($dsn,$user,$password);
$dbh->query('SETNAMES utf8');

$sql = 'SELECT staff_namae FROM mst_staff WHERE code=?';
$stmt=$dbh->prepare($sql);
$data[0]=$staff_code;
$stmt->execute($data);

$rec = $stmt->fetch(PDO::FETCH_ASSOC);
$staff_namae=$rec['staff_namae'];

$dbh = null;
}

catch (Exception $e)
{

print 'ただいま障害により、たいへんご迷惑をお掛けしております。';
exit();
}

?>

<h3>スタッフ削除</h3><br /> <br /> <br /> <h3>スタッフコード</h3><br /> <?php print $staff_code;?> <br /> <br /> <h3>スタッフ名</h3><br /> <?php print $staff_namae;?> <br /><br /> <h3>みのスタッフを削除してもよろしいですか?</h3><br /><br /> <form method="post" action="staff_delete_done.php"> <input type="hidden" name="staffcode" value="<?php print $staff_code;?>"> <br> <input type="hidden" onclick="history.back()" value="戻る"> <br /><br /> <input type="submit" value="削除実行"> </form> </div> </body> 削除実行 <?php

try
{

if (isset($_POST["staffcode"])) {
$staff_code = $_POST['staffcode'];
}

$dsn='mysql:dbname=shopdb;host=localhost';
$user='root';
$password='';
$dbh=new PDO($dsn,$user,$password);
$dbh->query('SETNAMES utf8');

$sql = 'DELETE FROM mst_staff WHERE code? = delete code';
$stmt = $dbh->prepare($sql);
$data[0] = $staff_code;
$flag = $stmt->execute(array($data[0]));

$dbh = null;

if ($flag){
print ('データーを削除しました。<br />');
}
else{
print ('データーを削除できませんでした。<br />');

}
}
catch(Exception $e)
{

print 'ただいま障害により、たいへんご迷惑をお掛けしております。';
exit();
}

?>

<h3><a href="staff_list.php">スタッフ一覧へ</a></h3>

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答4

0

正しいSQL文は以下のように書かなければなりません。

php

1$staffcode = $_POST['staffcode']: 2$sql = 'DELETE FROM mst_staff WHERE code = :code'; 3$stmt = $dbh->prepare($sql); 4$stmt->bindValue(":code", $staffcode, PDO::PARAM_INT); 5$stmt->execute(); 6echo $stmt->rowCount() . "is deleted";

MySQL公式サイトのマニュアルのDELETE文の構文がこうなっています。

SQL

1DELETE [LOW_PRIORITY] [QUICK] [IGNORE] FROM tbl_name 2 [PARTITION (partition_name,...)] 3 [WHERE where_condition] 4 [ORDER BY ...] 5 [LIMIT row_count]

投稿2017/09/24 02:04

naohiro19_

総合スコア178

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

このあたりのbindする辺りがうまくできていないんじゃないでしょうかね?
$sql = 'DELETE FROM mst_staff WHERE code? = delete code';

code=?
でうまくいかないでしょうか?

ちなみに最終的に画面に表示されている情報や、実際にテーブルにどんなデータが入っているかなど分かるとより皆さん解析がしやすいかと思いますよ^^

投稿2014/12/19 06:02

AOta

総合スコア7

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

kenjikobayashin

2014/12/19 10:13

ありがとうございます。 さっそく、$sql = 'DELETE FROM mst_staff WHERE code=?';をためさせていただきましたが、やはりelseの結果になりました。 明日にもう一度しっかりと悩んでみて、ご指摘いただいたことを活かさせていただいて質問を編集して投稿させていただきます。
guest

0

$flag の中には何が入っていますか?(var_dump で出してみて下さい。)
PHPエラー、MySQLエラーは表示されていませんか?
DELETEクエリ実行後の mst_staff テーブルはどうなっていますか?(データは削除されていますか?)

これらが分かれば原因が特定出来るとおもうのですが・・・

投稿2014/12/19 04:32

popoko

総合スコア27

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

popoko

2014/12/22 07:10

削除実行 <?php try { if (isset($_POST["staffcode"])) { $staff_code = $_POST['staffcode']; echo '$staff_code : ' . $staff_code; } $dsn='mysql:dbname=shopdb;host=localhost'; $user='root'; $password=''; $dbh=new PDO($dsn, $user, $password); $dbh->query('SETNAMES utf8'); $sql = 'DELETE FROM mst_staff WHERE code = :staff_code'; $stmt = $dbh->prepare($sql); $stmt -> bindValue(':staff_code', $staff_code, PDO::PARAM_STR); $flag = $stmt->execute(); $dbh = null; if ($flag){ print ('データーを削除しました。<br />'); } else { print ('データーを削除できませんでした。<br />'); } } catch(PDOException $e) { print 'ただいま障害により、たいへんご迷惑をお掛けしております。'; exit('DB ErrMsg : ' . $e->getMessage()); } ?> を試してみて下さい。 何かしらのエラーが画面に表示されるはずです。
退会済みユーザー

退会済みユーザー

2017/09/24 02:24

気づけばプロ並みPHP は販売停止すべきだよなぁ・・・  毎年この時期よくみる・・・
guest

0

質問の内容が不明瞭で回答のしようがないのですが、DELETEの処理はどこにあるのでしょうか?
また、DELETEの結果が得られないとは具体的にどういう状態なのでしょうか?

SQLのDELETEの構文エラーが見受けられます。
http://dev.mysql.com/doc/refman/5.6/en/delete.html

エラーを出力するようにして、DELETEの部分のエラーを出力してみると以下のようになっていました。

SQLSTATE[42000]: Syntax error or access violation: 1064 You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ''1' = delete code' at line 1

単純なSQL構文エラーだと思います。

投稿2014/12/18 08:52

TaMaMhyu

総合スコア1356

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

TaMaMhyu

2014/12/19 05:50

エラーを出力しないと、机上・脳内だけなので、結局何が問題なのかよく分からないと思います。 まずは、エラーを出力するコードに変更することから始めたほうがいいと思います。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問