SQL文の実行結果を変数で受けて、それを連想配列に格納したいです。
(カラム名を連想配列のキーにします。)
また、値をHTMLエスケープ処理したいと考えています。
下記のソースを書いてみましたが、配列$all[]にうまく入りません。
$qresult = mysql_query($qstring);
$all = array();
while (list ($key, $val) = mysql_fetch_assoc($qresult)){
$all[$key] = htmlentities($val, ENT_QUOTES,EUCJP);
}
また、3行目をeach(mysql_fetch_assoc($qresult))に変更してもみましたが、
「Variable passed to each() is not an array or object」エラーが出ます。
mysql_fetch_assocの戻り値は連想配列では無いのでしょうか。
$qresult = mysql_query($qstring);
$all = array();
while ($rec = mysql_fetch_assoc($result)){
$all[] = $rec;
}
上記だと問題なく取得出来るのですが。。。
何が悪いのでしょうか。
No.1
- 回答日時:
list ($key, $val) = mysql_fetch_assoc($qresult))
↑が意味不明の文になってますね。
どういう結果を得たいのでしょう?連想配列の配列なら後者のプログラムで良さそうですが。
例えば、
id,key,name(カラム名)
1,a1,foo
2,b2,bar
3,c3,baz
というデータだとして、$allはどうなって欲しい?
あと、HTMLエスケープ処理は、HTMLに出力する直前で行います。
$all[0]=([id] => 1 [key] => a1 [name] => foo)
$all[1]=([id] => 2 [key] => b2 [name] => bar)....
で、その後、Smartyを使って、下記のようにHTMLに一気に吐き出します。
{section name=tloop loop=$all}
{$all[tloop].id}
{$all[tloop].key}
{$all[tloop].name}
{/section}
そのため、HTMLエスケープ処理したものを、連想配列の値として代入しておきたいのです。
No.2
- 回答日時:
> mysql_fetch_assocの戻り値は連想配列では無いのでしょうか。
フィールド名を配列のキーとした連想配列ですよ。
一度、print_r() してみると分かりやすいかと思います。
なので、#1のお礼に書かれている結果を求めたいなら、#1さんも書かれている通り、質問の後者のスクリプトで良いと思うのですが。
この回答への補足
自己解決しました。
$all = array();
while ($rec = mysql_fetch_assoc($result)){
while (list ($key, $val) = each($rec)){
$rec[$key] = htmlentities($val, ENT_QUOTES,EUCJP);
}
$all[] = $rec;
}
これでHTMLエスケープした値を連想配列に代入できました。
一旦、mysql_fetch_assoc()を配列に受けてからでないと、each()で使えないんですね。
list ($key, $val) = each(mysql_fetch_assoc());ではダメで、
$arr=mysql_fetch_assoc();list ($key, $val) = each($arr);にしないといけないんですね。
やっぱりwhileループ2回(ループ1回目:連想配列の取得、ループ2回目:値のHTMLエスケープ)で行くしかないのかな。
ループが2回必要なのが、回りくどい感じがするので、1回目のループで、HTMLエスケープも行ってみたかったのです。
No.3
- 回答日時:
あ~、なるほど。
質問の意図を勘違いしてました。ようするに二次元配列の時の中身を、さらっとエスケープしたかったわけですね。
他に知識がある人なら、別のやり方するかもしれませんが、俺も 二重ループさせる方法しか思いつきません。
ただ、そちらと違うのは、中のループは foreach()を使います。
ま、やってる事は 全く一緒なんですけどね~。
while (list ($key, $val) = each($rec)){
↓
foreach($rec as $key =>$val){
No.4ベストアンサー
- 回答日時:
#1です。
>そのため、HTMLエスケープ処理したものを、連想配列の値として代入しておきたいのです。
前回書いたように、エスケープ処理した物を変数に格納するという考え方がおかしいです。HTMLエスケープ処理は、HTMLに出力する直前で行います。
お書きになった
$qresult = mysql_query($qstring);
$all = array();
while ($rec = mysql_fetch_assoc($result)){
$all[] = $rec;
}
で、SQL結果を「連想配列の配列」として$allに格納した上で、
{section name=tloop loop=$all}
{$all[tloop].id|escape:'htmlall'}
{$all[tloop].key|escape:'htmlall'}
{$all[tloop].name|escape:'htmlall'}
{/section}
と出力時にエスケープするのが、正しいと思います。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- MySQL 参考書に従って入力したつもりでしたが、最後はエラーがでました。 1 2022/09/28 03:45
- SQL Server [SQLServer] テーブル名からカラム名を取得する 1 2022/08/23 21:20
- PHP 配列の値の更新方法について 1 2022/08/05 09:49
- MySQL MySQLのテーブル作成でハイフン - は使用できないのでしょうか? 2 2022/10/21 16:50
- フリーソフト 色々な形式の個人情報を後で参照しやすいようWindow10で管理したいのですが、どんな方法があるの? 1 2023/04/29 16:46
- C言語・C++・C# c言語の問題です 課題1 (二分探索木とセット) 大きさ size の配列 array を考える。す 2 2023/01/10 21:08
- C言語・C++・C# C言語初心者 ポインタについて、お助けください、、 2 2023/03/15 23:50
- MySQL 何にかが違うから エラーなんでしょうね! 2 2022/09/18 05:28
- MySQL テーブル作成です。どこかのスペルが間違っているか記号など スペースかな? 1 2022/10/01 05:08
- MySQL `picture` varchar(255) のコマンドで間違いないでしょうか? 1 2022/11/21 04:08
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
file_existsでファイル名の部分...
-
配列をループでたくさん宣言し...
-
PHPで多次元配列を一度に処理す...
-
$_SESSIONに二次元配列を使える...
-
foreachのなかで次のキーを参照...
-
チェックボックスが複数選択で...
-
重複しないランダム関数を教え...
-
チェックボックス複数選択 mys...
-
Smarty の演算方法
-
URLのサブドメインとドメイン部...
-
PHP pdo mysql 周りについて教...
-
postgresql関数をつかったレコ...
-
GOTO命令のようなことをPHPで
-
PHPのカッコ[ ]の使い方について
-
タブ区切りのデータでnullのデ...
-
PHPのループ数限界値について
-
プルダウンメニューでCSVデータ...
-
プログラミングのPythonのnoteb...
-
プルダウンメニューにDBの内容...
-
PHPのmin関数、「1」以上の数値...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
配列をループでたくさん宣言し...
-
file_existsでファイル名の部分...
-
$_SESSIONに二次元配列を使える...
-
foreachのなかで次のキーを参照...
-
String だと「 ByRef引数の型が...
-
配列を回すとき、最後の要素だ...
-
配列一致(要素順番は違うが内容...
-
PHPのカッコ[ ]の使い方について
-
ネストが深い時のforeachはどう...
-
チェックボックス複数選択 mys...
-
PHPで配列をPOSTデータで送った...
-
phpで、連想配列を普通の配列に...
-
PHP 多次元配列変数のデータ受...
-
postgresql関数をつかったレコ...
-
【PHP】配列内のある値以上をカ...
-
SQL文の実行結果を変数で受けて...
-
プルダウンメニューでCSVデータ...
-
Smartyのテンプレートからjavas...
-
PHPにてクラスを配列にすること...
-
CSVデータのn番目だけの値を取...
おすすめ情報