こんにちは。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で質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
- ・ゆるやかでぃべーと タイムマシンを破壊すべきか。
- ・歩いた自慢大会
- ・許せない心理テスト
- ・字面がカッコいい英単語
- ・これ何て呼びますか Part2
- ・人生で一番思い出に残ってる靴
- ・ゆるやかでぃべーと すべての高校生はアルバイトをするべきだ。
- ・初めて自分の家と他人の家が違う、と意識した時
- ・単二電池
- ・チョコミントアイス
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
配列をループでたくさん宣言し...
-
$_SESSIONに二次元配列を使える...
-
チェックボックスが複数選択で...
-
smartyで配列の中の同数値の数...
-
PHPのカッコ[ ]の使い方について
-
○番目から○番目までの取り出し...
-
レンタルサーバでMYSQLに...
-
漢字のソートについて
-
テキストの処理について
-
postgresql関数をつかったレコ...
-
返り値の配列中の1つの値のみ受...
-
file_existsでファイル名の部分...
-
String だと「 ByRef引数の型が...
-
foreach($ptr as $valueptr) の...
-
別ファイルに保存した文字列の...
-
チェックボックス複数選択 mys...
-
禁止ワード設定
-
PHP 配列の中身を全て変数に設定
-
SESSION変数の2次元配列
-
配列の要素数について
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
配列をループでたくさん宣言し...
-
$_SESSIONに二次元配列を使える...
-
String だと「 ByRef引数の型が...
-
file_existsでファイル名の部分...
-
漢字のソートについて
-
PHPのカッコ[ ]の使い方について
-
ネストが深い時のforeachはどう...
-
foreachのなかで次のキーを参照...
-
チェックボックス複数選択 mys...
-
配列一致(要素順番は違うが内容...
-
PHPにてクラスを配列にすること...
-
postgresql関数をつかったレコ...
-
PHP 配列の添字に変数は使えない?
-
PHP掲示板で新着順に表示させた...
-
URLのサブドメインとドメイン部...
-
SESSION変数の2次元配列
-
PHPで配列をPOSTデータで送った...
-
$_POSTを一括してサニタイズし...
-
Smartyを使って、テーブルを表示
-
【Smarty】foreach関数やsectio...
おすすめ情報