検索

ホームページ  >  に質問  >  本文

MySQL 側または Perl 側で SQL 結果に空の日付を入力するにはどうすればよいですか?また最も簡単な方法は何ですか?

<p>次のようなクエリを使用して、mysql テーブルから簡単な CSV を作成しています。</p> <pre class="brush:php;toolbar:false;">select DATE(date),count(date) by DATE(date) order by date asc;</pre> <p>次に、それらを Perl のファイルに直接ダンプします。 </p> <pre class="brush:php;toolbar:false;">while(my($date,$sum) = $sth->fetchrow) { CSV「$date,$sumn」を出力 }</pre> <p>ただし、データには日付のギャップがあります: </p> <pre class="brush:php;toolbar:false;">| 2008-08-05 | 4 | | 2008-08-07 | 23 |</pre> <p>欠落している日付をゼロカウントのエントリで埋めてデータを埋め込み、最終的に次のようにしたいと考えています。 <pre class="brush:php;toolbar:false;">| 2008-08-05 | 4 | | 2008-08-06 | 0 | | 2008-08-07 | 23 |</pre> <p>私は、月の日付の配列といくつかの数学を使用して、非常に不器用な (ほぼ確実にバグが多い) 回避策をまとめましたが、mysql または perl には、より直接的な方法があることは間違いありません。 </p> <p>なぜ私がそんなに愚かなのかについての天才的なアイデア/提案はありますか? </p>
<p>最終的に、いくつかの理由から、ストアド プロシージャを使用して、必要な日付範囲を処理する一時テーブルを生成することにしました。
P粉448346289P粉448346289503日前552

全員に返信(2)返信します

  • P粉733166744

    P粉7331667442023-08-25 00:59:49

    この問題に対処する必要があり、欠落している日付を埋める必要があるとき、私は実際に、関心のあるすべての日付だけを含む参照テーブルを作成し、日付フィールドのデータ テーブルを結合しました。粗雑で粗雑ですが、機能します。

    リーリー

    出力に関しては、CSV を手動で生成する代わりに、SELECT INTO OUTFILE を使用します。こうすることで、特殊文字のエスケープについて心配する必要がなくなります。

    返事
    0
  • P粉593649715

    P粉5936497152023-08-25 00:39:00

    サーバー側で同様のことが必要な場合は、通常、2 つの時点の間のすべての可能な日付を含むテーブルを作成し、クエリ結果を使用してこのテーブルに左結合を実行します。次のようなもの:

    リーリー

    この特定のケースでは、クライアント側で何らかのチェックを行い、現在の日付が前日の翌日でない場合は文字列を追加した方がよいでしょう。

    返事
    0
  • キャンセル返事