熱點推薦:
您现在的位置: 電腦知識網 >> 編程 >> MySQL >> 正文

MySQL處理空值時需要注意的兩個問題

2013-11-23 21:01:18  來源: MySQL 

  MySQL數據庫是一個基於結構化數據的開源數據庫SQL語句是MySQL數據庫中核心語言不過在MySQL數據庫中執行SQL語句需要小心兩個陷阱

  陷阱一空值不一定為空

  空值是一個比較特殊的字段在MySQL數據庫中在不同的情形下空值往往代表不同的含義這是MySQL數據庫的一種特性如在普通的字段中(字符型的數據)空值就是表示空值但是如果將一個空值的數據插入到TimesTamp類型的字段中空值就不一定為空此時為出現什麼情況呢(如下圖)?

  MySQL中處理空值時要小心兩個個陷阱

  我先創建了一個表在這個表中有兩個字段User_id(其數據類型是int)Date(其數據類型是TimesTamp)現在往這個表中插入一條記錄其中往Date字段中插入的是一個NULL空值可是當我們查詢時其結果顯示的卻是插入記錄的當前時間這是怎麼一回事呢?其實這就是在MySQL數據庫中執行SQL語句時經常會遇到的一個陷阱空值不一定為空在操作時明明插入的是一個空值的數據但是最後查詢得到的卻不是一個空值

  在MySQL數據庫中NULL對於一些特殊類型的列來說其代表了一種特殊的含義而不僅僅是一個空值對於這些特殊類型的列各位讀者主要是要記住兩個一個就是筆者上面舉的TimesTamp數據類型如果往這個數據類型的列中插入Null值則其代表的就是系統的當前時間另外一個是具有auto_increment屬性的列如果往這屬性的列中插入Null值的話則系統會插入一個正整數序列而如果在其他數據類型中如字符型數據的列中插入Null的數據則其插入的就是一個空值

  陷阱二空值不一定等於空字符

  在MySQL中空值(Null)與空字符()相同嗎?答案是否定的請大家先來看下圖的演示

  MySQL中處理空值時要小心兩個個陷阱

  在同一個數據庫表中同時插入一個Null值的數據和一個空字符的數據然後利用Select語句進行查詢最後顯示的結果如上圖所示顯然其顯示的結果是不相同的從這個結果中就可以看出空值不等於空字符這就是在MySQL中執行SQL語句遇到的第二個陷阱在實際工作中空值數據與空字符往往表示不同的含義數據庫管理員可以根據實際的需要來進行選擇如對於電話號碼等字段可以默認設置為空值(表示根本不知道對方的電話號碼)或者設置為空字符(表示後來取消了這個號碼)等等由於他們在數據庫中會有不同的表現形式所以數據庫管理員需要區別對待筆者更加喜歡使用空值而不是空字符這主要是因為針對空值這個數據類型有幾個比較特殊的運算字符如果某個字段是空字符數據庫中是利用字段名稱來代替相反如果插入的是空值則直接顯示的是NULL這跟其他數據庫的顯示方式也是不同的

  一是IS NULL 和IS NOT NULL關鍵字如果要判斷某個字段是否含用空值的數據需要使用特殊的關鍵字其中前者表示這個字段為空後者表示這個字段為非空在Select語句的查詢條件中這兩個關鍵字非常的有用如需要查詢所有電話號碼為空的用戶(需要他們補充電話號碼信息)就可以在查詢條件中加入is not null關鍵字

  MySQL中處理空值時要小心兩個個陷阱

  二是Count等統計函數在空值上也有特殊的應用如現在需要統計用戶信息表中有電話號碼的用戶數量此時就可以使用count函數同時將電話號碼作為參數來使用因為在統計過程中這個函數會自動忽略空值的數據此時統計出來的就是有電話號碼的用戶信息如果采用的是空字符的數據則這個函數會將其統計進去如下圖所示統計剛才建立的兩條記錄時系統統計的結果是而不是可見系統自動將Null值的數據忽略掉了


From:http://tw.wingwit.com/Article/program/MySQL/201311/29455.html
    推薦文章
    Copyright © 2005-2013 電腦知識網 Computer Knowledge   All rights reserved.