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

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

ただいまの
回答率

90.50%

  • PHP

    23945questions

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

  • MySQL

    6966questions

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

  • phpMyAdmin

    803questions

    phpMyAdminはオープンソースで、PHPで書かれたウェブベースのMySQL管理ツールのことです。

【PHP】【MYSQL】'SQLSTATE[42S22]: Column not found: 1054の解決方法【Unknown column】

解決済

回答 2

投稿

  • 評価
  • クリップ 1
  • VIEW 4,351

shimane

score 82

現在PHP/MYSQLの勉強をしている者です。

今回、記事・URL・更新日時といった情報をmysqlを使ってデータベースに保存して
phpを使って表示するというサイトを作りながら勉強をしています。

【実行してみた事】

記事タイトル・記事URL・更新日時・コメント数を取得して
PHPでMYSQLを使ってデータベースに登録。

PHPにてMYSQLに入っているデータを取り出して表示。

ここまではネットで調べたり、書籍で調べたりでなんとか実現する事が出来ました。

そこで1歩前に進んで

データを登録する際に、
既に登録している記事タイトルやURLだった場合に
「重複してデータベースに登録を防ぐ為」に

「コメント数」・「更新時間(何分前・何時間前・何か月前などの)」だけを最新の情報に更新するという風に
設定してみました。

//ON DUPLICATE KEY UPDATEに jikan = $jikan, を設定するとエラーが表示されます。
//jikan = $jikan,以外の「comment = $comment,」と
//「created = now()」だけではエラーが表示されず成功します。

//$jikanには「2分前」「1時間前」といった文字列が入っています。
//$commentには「10」「100」といった数値が入っています。

$sql = "insert into bbs (title, url, body, name, comment, jikan,
created) values (:title,:url,:body,:name,:comment,:jikan,now())
ON DUPLICATE KEY UPDATE
comment = $comment,
jikan = $jikan,
created = now()
";
$stmt = $db->prepare($sql);
$stmt->execute([
  ':title' => $title,
  ':url' => $url,
  ':body' => $body,
  ':name' => $name,
  ':comment' => $comment,
  ':jikan ' => $jikan 
]);

ON DUPLICATE KEY UPDATE
にて
jikan = $jikan,を設定した時に下記のエラーコードが表示されました。

Fatal error: Uncaught exception 'PDOException' with message 'SQLSTATE[42S22]: Column not found: 1054 Unknown column '2分前' in 'field list'' in 

日本語訳:
SQLSTATE [42S22]:列が見つかりません:1054'フィールドリスト 'の' 2分前 'の不明な列' '

テーブルにあるカラムには
title, url, body, name, comment, jikan,created があります。

プライマリーキー:id
ユニークキー:title
ユニークキー:url
に設定しています。

エラーが表示されない変数には「日本語」が入っていなく「数値」や「日付」
エラーが表示される変数「$jikan」には「2分前」「5分前」といった日本語が入っているので
それが原因なのかも?と考え
色々と試してみたのですが上手くいかず、頭が混乱してしまっている状態です。

ネットで色々調べてみたのですが、解決する事が出来ませんでした。
解決方法をご存知の方や、何かお気付きの点がある方は
お力をお貸し頂けると嬉しいです。
どうかお願いします。

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 2

checkベストアンサー

+1

$sql = "insert into bbs (title, url, body, name, comment, jikan,
created) values (:title,:url,:body,:name,:comment,:jikan,now())
ON DUPLICATE KEY UPDATE
comment = '$comment',
jikan = '$jikan',
created = now()
";


って言う感じでシングルコーテーション囲んでないからではと思います。

※プリペアドステートメント使ってるから

$sql = "insert into bbs (title, url, body, name, comment, jikan,
created) values (:title,:url,:body,:name,:comment,:jikan,now())
ON DUPLICATE KEY UPDATE
comment = :comment,
jikan = :jikan,
created = now()
";


のほうがいいかもしれませんね

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2017/08/25 12:09

    助けて頂いて有難うございます!ああでもない、こうでもないと頭の中がごっちゃごちゃになってしまってたので本当に助かりました!

    キャンセル

+1

ON DUPLICATE KEY UPDATE
でデータを再利用するときはvaluescが使えるかもしれません

insert into bbs (title, url, body, name, comment, jikan,
created) values (:title,:url,:body,:name,:comment,:jikan,now())
ON DUPLICATE KEY UPDATE
comment = values(comment),
jikan = values(jikan),
created = now()

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2017/08/25 12:11

    教えて頂いて有難うございます! 「valuesc」についてはネットで調べても まったく記載がなかったので勉強になりました。とても分かりやすい記述で、初心者の私にも使えそうです、大感謝です!

    キャンセル

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

  • PHP

    23945questions

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

  • MySQL

    6966questions

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

  • phpMyAdmin

    803questions

    phpMyAdminはオープンソースで、PHPで書かれたウェブベースのMySQL管理ツールのことです。