ハードディスクメンテナンス ブログ

投稿記事数8,000以上!PC,カメラ,オーディオ,ラジオ,航空,旧ゲームなど

DATE型にNULLを格納する方法(0000-00-00の回避,MySQL)

   

>>高還元のクレジットカード比較 期間限定のキャッシュバックなど!<<


MySQLで、フィールド date を、DATE型、NULL許可で作成する。

DATE型

dateには YYYY-MM-DD を格納する設計であるが date が空欄にされた場合、NULLとすべきである(値がなくゼロでもない)。

NULL

しかし、INSERTすると、0000-00-00という値で格納されてしまうことがある。

0000-00-00

これをNULLにするには、SQL文組み立ての中で、

$date = “” ;

$sql = “INSERT INTO test (date,time)” ;

$sql .= “VALUES(” ;

if(!$date){
$sql .= “NULL,” ;
}else{
$sql .= “‘”.$date.”‘,” ;
}

$sql .= “‘”.$time.”‘)” ;

$res = mysql_query($sql,$conn) or die(“insert_error”) ;

として分岐すればよい。

この時、

if(!$date){
$sql .= “NULL,” ;
}else{
$sql .= “‘”.$date.”‘,” ;
}

と、シングルクォーテーションでNULLを囲んでしまうと、0000-00-00という値で格納されてしまう。

デーブルの「構造」にて、

①ヌル(NULL)にチェックを入れると、自動的にデフォルト値がNULLとなる。

②ヌル(NULL)のチェックを外し、デフォルト値にもNULLが入ったままだとエラーになる(当然)。

③ヌル(NULL)のチェックを外し、デフォルト値をNoneにする。

NULLが入った状態で③の操作をしてしまうと、NULLは0000-00-00となってしまい、その後①に戻しても、値はNULLには戻らず、0000-00-00のままとなる。

NULL→0000-00-00

同じTIME型についても、同様だろう。

スポンサーリンク
基礎からのMySQL 改訂版 (プログラマの種シリーズ SE必修! )
西沢 夢路
ソフトバンククリエイティブ
売り上げランキング: 8,289
MySQL全機能バイブル ~現場で役立つAtoZ~
鈴木 啓修
技術評論社
売り上げランキング: 331,043




sha-bc@336×280

sha-bc@336×280


sha-bc@336×280

sha-bc@336×280

  関連記事

no image
Debian7.4をハードウェアRAIDにインストールする際の設定(RAID1,ミラーリング)

Debianで起動ドライブを含んでソフトウェアRAID(ミラーリング)を組むと、 …

twitter
Twitterのタイムラインをサイトに埋め込む方法 – コードをユーザー毎に変化させるには?

Twitterのタイムラインをサイトに埋め込むのには、Twitetrにログインし …

NAS
首都大学東京の学内設置NASが踏み台にされ、スパムメールが送信される事案が発生

約10万通のスパムメール送信。 スパムメールは、15時06分から16時37分の間 …

no image
Debian7.4でWEBサーバーを立てる(Apache,MySQL,PHP,phpMyAdmin,FTP)

Windows環境でもXAMPPを入れると環境が整うので(その端末なのでFTP不 …

no image
DISTINCTの逆(重複を抽出するSQL文)

以下のようなテーブルがある。 id,item_code,reg_date 1,0 …

no image
時,分,秒を[年月日時分秒]から取り出す(MySQL,hour,minute,second,extract,date_format)

あるテーブルの列(カラム)reg_timeには、年月日時分秒がY-m-d H:i …

no image
PowerEdgeT105のCPU換装(2コアから3コアに)

DELLのサーバーであるPowerEdgeT105のCPUを ①Athlon64 …

no image
Debian CPU確認 (Processor,スペック)

rootで cat /proc/cpuinfo でCPUの確認が可能。 以下、表 …

no image
Apache Server Status の設定 (Apache2.2.22 ,Debian7.4)

Apache/2.2.22 (Debian7.4) ローカルの試験サーバーのIP …

no image
サーバー情報の表示内容(ServerTokens)変更 (Apache2.2.22 ,Debian7.4)

Apache/2.2.22 (Debian7.4) /etc/apache2/c …