勉強したことのメモ

webプログラマが勉強したことのメモ。

MySQLで月別に集計を行う。あと日付時刻関数。

   

現在進行形でやっているデータ集計系だけど
新たな発見があったのでメモ。

■日付時刻関数
datetime型のカラムがあってフォーマットは
YYYY-MM-DDという形。時間はなし。

で、2012年分を抽出する際に、

WHERE ymd BETWEEN '2012-01-01' AND '2012-12-31'

もしくは、

WHERE ymd >= '2012-01-01' AND ymd <= '2012-12-31'

として書いていた。
が、日付時刻関数というものがあるみたい。

■参考サイト
http://phpjavascriptroom.com/?t=mysql&p=datetime

今回のケースだと、

WHERE YEAR(ymd) = '2012'

とすごくスマートに書ける。

■月別で集計を行う
やりたかったことは年間のデータを月別に分けて
1つのページに表示させたかった。

例えば、

2012年 合計 10000
1月 1021
2月 894
3月 777
....
12月 1509

みたいな感じ。
1ヶ月ずつ12回SQLを打つのか、1年分をSUM使わずに
丸々取得してPHPで処理するのかみたいなこと考えて
しまったけど、ちゃんとやり方があるみたい。

 

SELECT
code,
DATE_FORMAT(aaaymd,"%Y-%m") AS ymd
FROM table
WHERE code = 111
AND aaaymd BETWEEN "' . $start_ymd . '" AND "' . $end_ymd . '"
GROUP BY ymd

■参考サイト
http://www3441ui.sakura.ne.jp/wordpress/?p=654

●年●月ごとにGROUP BYを行っているみたい。
で、WHERE句で1年縛りにしたら良い。
DATE_FORMATって凄い。

 - MySQL

  関連記事

MySQLのエラーログ取得関数

場合によってログに出力させたい値が異なる場合があったのでメモ。 function ...

MySQLiでUPDATE文

MySQLiでUPDATE文 ■ソース $mysqli = new mysqli ...

MySQLでユニークキーをはる

MySQLでseqとcodeみたいなものをあわせて ユニークキーをはりたかった。 ...

mysqlでrootのパスワードが分からない場合

pleskで管理しているサーバがあり、mysqlのrootのパスワードが分からな ...

市区町村のMySQL用データが欲しい

都道府県と市区町村が連携したセレクトメニューを作成したかった。具体的には大阪府を ...

MySQLでテーブル構造とデータをコピーする

MySQLで既にあるテーブルとデータに対して実験を行う必要があった。本番テーブル ...

LEFT JOIN

なんとなくで覚えていたMySQLのLEFT JOINを 最近使うことがあり、上手 ...

phpMyAdminでのエクスポート/インポート

DBのバックアップを取る際にエクスポート/インポートを行うが、 データ件数が多い ...

sshでMySQLの操作

今までMySQLを操作するときはphpmyadminから 行っていたけど、php ...

phpmyadminからプロセスの停止

重たいSQL文を叩いた際、どうにも処理できず メモリ使用率が100%から下がらな ...