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

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

ただいまの
回答率

90.62%

  • PHP

    19813questions

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

  • MySQL

    5690questions

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

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

受付中

回答 4

投稿 ・編集

  • 評価
  • クリップ 0
  • VIEW 1,050
質問を再編集させていただきます以前から質問させていただいてる件ですが、エラーコードの設定が出来なく分かりにくいのですがどうか教えてください。
以下の内容で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>
  • 気になる質問をクリップする

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 4

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/19 14:50

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

    キャンセル

0

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

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

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2014/12/22 16: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 11:24

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

    キャンセル

0

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

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

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

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2014/12/19 19:13

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

    キャンセル

0

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

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


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

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

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

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

  • ただいまの回答率 90.62%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る

  • PHP

    19813questions

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

  • MySQL

    5690questions

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

  • トップ
  • PHPに関する質問
  • 何度も伺って済みません、試行錯誤してますがDELETE文が結果を出せないので教えてください