お世話になります。
現在、PHPで作成し運営しているサイトでキーワード検索を設置しているのですが、「野」や「三」など漢字一文字で検索すると
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 'AND ××× = AND ○○○ =' at line 3
というエラーになってしまいます。
別の漢字でエラーにならない場合もありますが、多くの漢字でエラーになってしまい、ググってみたものの対処法がわからず困っています。記述は下記の通りです。
$key = addslashes($_POST["keyword"]);
$db= new mysqli($host, $username, $password, $database);
if(mysqli_connect_errno())
die("Can't connect database : " . mysqli_connect_errno());
if(!$db->query("SET NAMES 'utf8'"))
die(mysqli_error($db));
$query = <<< EOS
SELECT *
FROM {table}
WHERE name LIKE '%{$key}%'
AND kana LIKE '%{$key}%'
EOS;
if(!$result = $db->query($query))
die(mysqli_error($db));
色々と検証し、kanaのフィールドは問題なくnameのフィールドで
エラーが発生しているということが分かりました。また「LIKE '%{$key}'」は問題なく「LIKE '%{$key}'」の前方一致でエラーが起きているみたいです。
ちなみにREGEXPでも試してみたのですがダメみたいです。
対処法をご存知の方がいましたら、よろしくお願いいたします。
No.2ベストアンサー
- 回答日時:
質問されてる事とエラーメッセージの辻褄がまったく合ってないですね。
エラーメッセージはSQL systaxに対することであり、
Queryを見る限り、私の環境Ver.5.0.75ではどんな値をいれてもマッチしなけば
"Empty"が返ってくるだけです。
検証はMysql server上でされたのですか?
たまたま検証中にsystaxが間違っており、それと今回に件を混同されている
ということではないですよね?
MysqlのVersionを表記されると何かでるかも知れません。
No.1
- 回答日時:
最近はプリペアドステートメントを使うのが一般的でしょう。
また、なんとも言えませんが、とりあえずPOSTデータを洗浄する前に
文字コードを合わせる処理をいれてみてはどうでしょうか?
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
字面がカッコいい英単語
あなたが思う「字面がカッコいい英単語」を教えてください。
-
フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
あなたが普段思っている「これまだ誰も言ってなかったけど共感されるだろうな」というあるあるを教えてください
-
映画のエンドロール観る派?観ない派?
映画が終わった後、すぐに席を立って帰る方もちらほら見かけます。皆さんはエンドロールの最後まで観ていきますか?
-
海外旅行から帰ってきたら、まず何を食べる?
帰国して1番食べたくなるもの、食べたくなるだろうなと思うもの、皆さんはありますか?
-
天使と悪魔選手権
悪魔がこんなささやきをしていたら、天使のあなたはなんと言って止めますか?
-
like句を使って日本語を検索する場合
MySQL
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・【お題】絵本のタイトル
- ・【大喜利】世界最古のコンビニについて知ってる事を教えてください【投稿~10/10(木)】
- ・メモのコツを教えてください!
- ・CDの保有枚数を教えてください
- ・ホテルを選ぶとき、これだけは譲れない条件TOP3は?
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・【コナン30周年】嘘でしょ!?と思った○○周年を教えて【ハルヒ20周年】
- ・ハマっている「お菓子」を教えて!
- ・最近、いつ泣きましたか?
- ・夏が終わったと感じる瞬間って、どんな時?
- ・10秒目をつむったら…
- ・人生のプチ美学を教えてください!!
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・都道府県穴埋めゲーム
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
SQLのエラー(~付近に不適切な...
-
Oracle 8i コンマ(,)を含むデ...
-
GROUP BYでエラーが発生
-
全ストアドを対象に文字列を置...
-
レポートが開けない。
-
ACCESS ADOでupdateが効かない
-
エクセルマクロで指定範囲内の...
-
エクセルからSQLサーバー ...
-
複数の表の外部結合について
-
PostgreSqlでFunctionの作成に...
-
sqlで文字列を最後に追加したい
-
BCPコマンドのリダイレクト値が...
-
ORA-1036??
-
自作関数を含んだクエリをエク...
-
エラー:823 重大度:24 状態...
-
「代表」という文字が入りません
-
バッチプログラムでSQLSever200...
-
アクセスでの通常のマクロの実...
-
SQLサーバー接続 特定のPCがWin...
-
Excel-VBAの「しばらくお待ちく...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Oracle 8i コンマ(,)を含むデ...
-
SQLのエラー(~付近に不適切な...
-
PostgreSqlでFunctionの作成に...
-
GROUP BYでエラーが発生
-
エクセルマクロで指定範囲内の...
-
バッチファイルからのBCP起動に...
-
ACCESSで作成したアプリケーシ...
-
オブジェクト名 '<table>' が無...
-
何も表示されない実行時エラー...
-
ACCESS ADOでupdateが効かない
-
ACCESS2000ディスクまたはネッ...
-
エクセルからSQLサーバー ...
-
レポートが開けない。
-
sqlで文字列を最後に追加したい
-
Access2000環境に対応するMid関...
-
エクセルのグループボックス枠...
-
ストアドの戻り値(配列)について
-
SQLServerのエラー1069について
-
Accessのレポートが新規作成で...
-
SQLserverのIF文について
おすすめ情報