こんにちは。mysql_fetch_array()でテーブルに入っていないレコードも取得したいのですが、どのようにすればよろしいでしょうか。
テーブルはこんな感じです。
仕事 NUM
1 1
2 1
4 1
5 1
その上で、PHPはこのようになっています。
//データの選択
$sql = "SELECT job, COUNT(*) as num FROM org GROUP BY job";
$res = db_query($sql, $conn);
//データの出力
while ($row = mysql_fetch_array($res, MYSQL_ASSOC)) {
$array = array(
"job"=>$row["job"],
"num"=>$row["num"]
);
array_push($array, array(
"job"=>$row["job"],
"num"=>$row["num"]
));
$tmp[] = $array;
}
return $tmp;
このPHPのあと、Smartyに値を渡し、.tplで「A職(○件)」というようなことをやっています。
このときにフィールド「仕事」のレコード「3」は1つもデータが登録されていない状態です。そのためか、現状ではNULL値として扱われるようで、配列$rowに値を渡せず、.tplのほうではデータが表示されません。そこで、レコード「3」にデータを登録せずに、NULL値ではなく、例えば0などの値を渡したいと思います。
どのようなコードを書けば値を渡せるのでしょうか。よろしくお願いします。
A 回答 (3件)
- 最新から表示
- 回答順に表示
No.3
- 回答日時:
ANo. 1 です。
そもそも mysql_fetch_array にこだわる必要はあるのですか?
mysql_fetch_array は SQL で引っ張ってきたデータを連想配列に代入する関数のようですね。
私なら単純に mysql_fetch_row を使いますが。。。
あと、while 文の中身も理解できませんでした。
1. mysql_fetch_array で取得した連想配列を変数 $array に代入。
2. mysql_fetch_array で取得した連想配列を配列 $array に配列要素として追加。
3. 1.~2. で得られた $array を配列 $tmp に配列要素として追加。
を繰り返しているように見えるのですが。。。違いますか?
単に下記のように job 番号をインデックスとした配列に各 job での num の合計数を代入すれば
良いように思えますが。
$job_data[ job 番号 ] = num の合計数
Smarty を使ったことがないので、Smarty に渡すためにどのような配列を作成すれば
良いのかはわかっていません。
以下は参考までに。手元に PHP + MySQL 環境が無いので未検証です。
==== テーブル定義 ====
テーブル名: org
列名:
job
num
==== テーブル定義ここまで ====
==== コード ====
//job 番号の最大値用
$max_job = 0;
//DB への問い合わせ準備
$sql = "SELECT job, COUNT(num) as total_num FROM org GROUP BY job";
$res = db_query($sql, $conn);
//データの取得
while ($row = mysql_fetch_array($res, MYSQL_NUM)) { //mysql_fetch_row と同じ
//job 番号の更新
if($max_job < $row[0]){
$max_job = $row[0];
}
//取得したデータを配列に格納
$job_data[$row[0]] = $row[1];
}
//データの入っていない要素に 0 を代入
for($i=1; $i<=$max_job; $i++){
if(is_null($job_data[$i]){
$job_data[$i] = 0;
}
}
//データを Smarty に渡す?
return $job_data;
==== コードここまで ====
※コードにはインデントとして全角スペースを入れています。実際に使うときは TAB にでも置換してください。
No.2
- 回答日時:
ANo. 1 です。
SQL 文は、列の名前を job と num だとして、
$sql = "SELECT job, SUM(num) as total_num FROM org GROUP BY job";
だと、どうでしょうか?
「うまくいかない」という内容(エラーなど)を書いてきてもらえると
アドバイスできますよ。
ありがとうございます。
どちらでも、
Warning: mysql_fetch_array(): supplied argument is not a valid MySQL result resource in 以降ファイルパス
になってしまいますね。元のコードの場合にprint_r関数で出力すると、
Array
(
[job] => 1
[num] => 25
[0] => Array
(
[job] => 1
[num] => 25
)
)
というふうに続きますが、1つもデータがないところに関してはそもそも値を引っ張って来れないので、出力もされません。
もう少しいろいろと試してみます。お礼が遅くなりました。ありがとうございます。
No.1
- 回答日時:
DB を読み終わった後に、配列を最初から最後まですべてチェックして
null を 0 に置き換えてやればよいのでは?
あるいは、最初に配列のすべての要素の値を 0 で初期化してから DB を
読み込んでやればどうですか?
あと、気になった点を1つ。
テーブルの列 NUM は仕事の数なのですよね?
で、SQL 文で仕事の総数を出そうとしているのですよね?
(違ったら以下は気にしないでください)
NUM が常に 1 ならば問題ないのですが、そうでないのなら、
$sql = "SELECT job, SUM(NUM) as num FROM org GROUP BY job";
になるような気がするのですが・・・
ありがとうございます。
$sql = "SELECT job, SUM(NUM) as num FROM org GROUP BY job";
このコードを試してみたのですが、ちょっとうまくいかないみたいで。配列の値をチェックしてNULL値に0を置き換えてやるという方法を模索してみます。
ありがとうございます。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- C言語・C++・C# C言語初心者 ポインタについて、お助けください、、 2 2023/03/15 23:50
- PHP クエリObjectをforeachで回す時に、次のレコードへ移動せずに次のレコードを取得したい 2 2022/07/28 15:29
- PHP 配列の値の更新方法について 1 2022/08/05 09:49
- C言語・C++・C# c言語の問題です 課題1 (二分探索木とセット) 大きさ size の配列 array を考える。す 2 2023/01/10 21:08
- PHP PHP MySql ページング 2 2022/09/20 06:38
- C言語・C++・C# C言語プログラム変更 2 2022/12/21 15:03
- PHP PHPでCSVを出力するさいに、ループの中で前の行の値を変更したい 3 2022/10/27 17:44
- PHP PHPSpreadsheetによる書き出し時のページネーション方法について 1 2023/03/20 10:35
- PHP 【PHP/MySQL】コード上で生成したクエリを基に集計クエリを作りたい 1 2022/07/28 15:06
- C言語・C++・C# c言語の問題の説明、各所ごとに 5 2023/07/26 11:03
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
配列を回すとき、最後の要素だ...
-
file_existsでファイル名の部分...
-
エラーの原因について
-
配列をループでたくさん宣言し...
-
配列の何番目かを出力したい
-
String だと「 ByRef引数の型が...
-
プルダウンメニューでCSVデータ...
-
チェックボックスが複数選択で...
-
postgresql関数をつかったレコ...
-
foreachのなかで次のキーを参照...
-
URLのサブドメインとドメイン部...
-
CSVデータのn番目だけの値を取...
-
ネストが深い時のforeachはどう...
-
Smartyのテンプレートからjavas...
-
smarty 同じ要素内で改行
-
配列一致(要素順番は違うが内容...
-
配列のbindValue方法について
-
Resource id #3 と表示されま...
-
行数が30万件ほどあるCSVから、...
-
プルダウンメニューにDBの内容...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
配列をループでたくさん宣言し...
-
String だと「 ByRef引数の型が...
-
file_existsでファイル名の部分...
-
foreachのなかで次のキーを参照...
-
$_SESSIONに二次元配列を使える...
-
PHPのカッコ[ ]の使い方について
-
$_SESSIONについて教えて下さい。
-
配列を回すとき、最後の要素だ...
-
ネストが深い時のforeachはどう...
-
配列一致(要素順番は違うが内容...
-
PHPにてクラスを配列にすること...
-
配列の値の更新方法について
-
postgresql関数をつかったレコ...
-
PHPで配列をPOSTデータで送った...
-
PHP 多次元配列変数のデータ受...
-
漢字のソートについて
-
チェックボックスが複数選択で...
-
$_POSTを一括してサニタイズし...
-
smarty 同じ要素内で改行
-
配列のbindValue方法について
おすすめ情報