
mysql+phpでWebアプリを作り始めた者です。
行き詰っている部分がありまして、教えて頂けると助かります。
select文の選択結果に対してのレコード番号を動的に取得したくて、下記のようなSQL文をphpの中で実行するため、下記のようなコードを書きました。
$sql="set @nm=0;select * from (select @nm:=@nm+1 as cnt, f01,f02 from tbl where f02="***") as a limit 0,10";
$rs = mysqli_query($cn, $sql);
$cnt = mysqli_num_rows($rs); // 総行数
$rs = mysqli_query($cn, $sql);
while ($row = mysqli_fetch_assoc($rs)) {
// 略
}
ここで、結果をphpで取得する部分の行で、
Warning: mysqli_num_rows() expects parameter 1 to be mysqli_result, boolean given in *****.php on line 70
Warning: mysqli_fetch_assoc() expects parameter 1 to be mysqli_result, boolean given in *****.php on line 289
というエラーが発生してしまい、結果が1件も返りません。
SQL>set @nm=0;select * from (select @nm:=@nm+1 as cnt, f01,f02 from tbl where f02="***") as a limit 0,10
と直接にSQLを入れた場合は、正常に結果が表示されます。
このレコード番号を取得するための変数を入れる前は、下記のようなSQLを実行していましたが、正常に動作しておりました。
$sql="select f01,f02 from tbl where f02="***" limit 0,10";
変数を含んだSQL文をphpで実行するのは無理なんでしょうか?
No.1ベストアンサー
- 回答日時:
まず、ダブルクォーテーションが競合しています。
$sqlに渡す外側に"をつかっているならwhere句のクォーテーションはシングルクォートにしてください
またmysqliならマルチクエリが実行可能だとは思いますが、なれない場合はやはり
1行ごとSQL文を実行したほうがいいでしょう。
$sql="set @nm=0";
$rs = mysqli_query($cn, $sql);
$sql="select * from (select @nm:=@nm+1 as cnt, f01,f02 from tbl where f02='***') as a limit 0,10";
$rs = mysqli_query($cn, $sql);
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
select文の実行結果に空白行を...
-
割合(パーセント)を求めるには?
-
LIMIT句で少なくとも1行は選択...
-
条件付けで集計したものをUNION...
-
テーブルの最後(最新)のレコー...
-
SQLローダーCSV取込で、囲み文...
-
単一グループのグループ関数で...
-
Oracleで「文字が無効です」の...
-
レコードの登録順がおかしい
-
AccessのSQL文で1件のみヒット...
-
where句中のtrim関数について
-
タイトル行を固定してソートしたい
-
テーブルレーコードをソートし...
-
ハイフンの入ったデータの並べ替え
-
【PL/SQL】FROM区に変数を使う方法
-
ファイルの漢数字の順番につい...
-
OUTER JOIN とgroup by
-
並べ替えについて
-
トランザクションログを出力せ...
-
SQL*Loader Append
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
select文の実行結果に空白行を...
-
割合(パーセント)を求めるには?
-
最大値の集計結果に関連データ...
-
SQLだけでselect結果に定数を加...
-
PHP+MySQLでグループごとの新着...
-
1つのSQLにしたいです
-
SQLで連続したカラムが何個ある...
-
24時間以内に更新されたデータ...
-
高速化のためのインデックスの...
-
mysqlのsql文について質問です
-
クロス集計のSQL
-
重複レコードを調べる
-
時間帯テーブルから直近空き時...
-
空きのID番号を取得する方法
-
timestamp型のgroup
-
SQLにて順列の抽出
-
mysql5でGROUP BYごとにLIMIT??
-
MySQLのサブクエリ
-
集計されたテーブルの結合
-
任意の上位の集計を取得するには?
おすすめ情報