こんにちは。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を探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・プリン+醤油=ウニみたいな組み合わせメニューを教えて!
- ・タイムマシーンがあったら、過去と未来どちらに行く?
- ・遅刻の「言い訳」選手権
- ・【大喜利】【投稿~11/12】 急に朝起こしてきた母親に言われた一言とは?
- ・好きな和訳タイトルを教えてください
- ・うちのカレーにはこれが入ってる!って食材ありますか?
- ・好きな「お肉」は?
- ・あなたは何にトキメキますか?
- ・おすすめのモーニング・朝食メニューを教えて!
- ・「覚え間違い」を教えてください!
- ・とっておきの手土産を教えて
- ・「平成」を感じるもの
- ・秘密基地、どこに作った?
- ・【お題】NEW演歌
- ・カンパ〜イ!←最初の1杯目、なに頼む?
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・ハマっている「お菓子」を教えて!
- ・【大喜利】【投稿~11/1】 存在しそうで存在しないモノマネ芸人の名前を教えてください
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・つい集めてしまうものはなんですか?
- ・自分のセンスや笑いの好みに影響を受けた作品を教えて
- ・【お題】引っかけ問題(締め切り10月27日(日)23時)
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・【大喜利】【投稿~10/21(月)】買ったばかりの自転車を分解してひと言
- ・ホテルを選ぶとき、これだけは譲れない条件TOP3は?
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・【コナン30周年】嘘でしょ!?と思った○○周年を教えて【ハルヒ20周年】
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
配列をループでたくさん宣言し...
-
PHPでドメイン検索?
-
PHPでJavaScriptの配列を読み取...
-
file_existsでファイル名の部分...
-
(PHP)入力されたテキストをデ...
-
配列どうしで同じ値があれば取...
-
php多次元配列のソート(usort...
-
SimpleXML関数で取得したXML要...
-
配列一致(要素順番は違うが内容...
-
タブ区切りのデータでnullのデ...
-
Smartyでtplファイルから配列を...
-
改行入り変数を改行を残したま...
-
3次元配列を2次元配列にする方...
-
PHPの$abc=$values["pqr"]["xyz...
-
smartyのsection内でloop番号を...
-
多次元配列のスマートな書き方
-
URL型の文字列からファイル名を...
-
C言語でCSVファイルの行数を読...
-
配列データのグループ別け
-
stream_get_contentsの代替関数
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
配列をループでたくさん宣言し...
-
foreachのなかで次のキーを参照...
-
$_SESSIONに二次元配列を使える...
-
String だと「 ByRef引数の型が...
-
file_existsでファイル名の部分...
-
postgresql関数をつかったレコ...
-
$_POSTを一括してサニタイズし...
-
PHPのカッコ[ ]の使い方について
-
配列一致(要素順番は違うが内容...
-
漢字のソートについて
-
ネストが深い時のforeachはどう...
-
○番目から○番目までの取り出し...
-
チェックボックスが複数選択で...
-
テーブルの行と列の入れ替えは可?
-
CSVデータのn番目だけの値を取...
-
PHPで配列をPOSTデータで送った...
-
PHP 配列の添字に変数は使えない?
-
正規表現
-
PHP 多次元配列変数のデータ受...
-
OCI で、SELECT結果行数を取得...
おすすめ情報