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

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

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

PDO(PHP Data Objects)はPHPのデータベース抽象化レイヤーです。

CodeIgniter

CodeIgniterは、PHP向けオープンソースのWebアプリケーションフレームワークです。CodeIgniterは覚える構文が少なく、自由度も高いため、PHPを理解していれば構築が簡単です。

Q&A

解決済

1回答

5528閲覧

DB検索条件でクエスチョンマークをプレースホルダーではなく文字として利用したい

taka.nico

総合スコア12

PDO

PDO(PHP Data Objects)はPHPのデータベース抽象化レイヤーです。

CodeIgniter

CodeIgniterは、PHP向けオープンソースのWebアプリケーションフレームワークです。CodeIgniterは覚える構文が少なく、自由度も高いため、PHPを理解していれば構築が簡単です。

0グッド

0クリップ

投稿2016/11/25 02:23

###前提・実現したいこと
SQLの中でクエスチョンマークをプレースホルダーとしてではなく文字列として使用したいのですが、どうしてもプレースホルダーとして認識されてしまうようです。
お手数お掛けしますが、解決策をご教示頂きたく宜しくお願いいたします。

###発生している問題・エラーメッセージ

Fatal error: Call to a member function num_rows() on a non-object

###該当のソースコード

php

1$sql = 'SELECT * FROM test_tbl WHERE word = "テストとは?" AND id1= ? AND id2 = ?'; 2$q = $this->db->query($sql, array($id1, $id2)); 3if ($q->num_rows() > 0) { 45}

###試したこと
'?'の前に''をつけても変わりませんでした。

php

1$sql = 'SELECT * FROM test_tbl WHERE word = "テストとは\?" AND id1= ? AND id2 = ?';

###補足情報(言語/FW/ツール等のバージョンなど)
PHP:5.5.37
CodeIgniter:2.2.1

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

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

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

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

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

guest

回答1

0

ベストアンサー

手元に環境が無いため、マニュアルを見ての推測による回答となりますが、、

以下では、どうでしょうか?

php

1$sql = 'SELECT * FROM test_tbl WHERE word = ' . $this->db->escape("テストとは?") . ' AND id1= ? AND id2 = ?'; 2$q = $this->db->query($sql, array($id1, $id2));

https://github.com/bcit-ci/CodeIgniter/blob/2.2-stable/user_guide/database/queries.html#L104

または

php

1$sql = 'SELECT * FROM test_tbl WHERE word = ? AND id1= ? AND id2 = ?'; 2$q = $this->db->query($sql, array("テストとは?", $id1, $id2));

https://github.com/bcit-ci/CodeIgniter/blob/2.2-stable/user_guide/database/queries.html#L128

投稿2016/11/25 03:29

KiyoshiMotoki

総合スコア4791

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

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

taka.nico

2016/11/25 05:13

早速のご回答ありがとうございました。 前者の方ではうまくいきませんでしたが、後者の方で解決させて頂きました。 この方法を聞けば当たり前なことだとは思いますが、思考が凝り固まっていて、目から鱗が落ちる思いでした。重ねて感謝申し上げます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問