欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解MySQL中的NULL值

 更新時間:2015年05月26日 17:53:48   投稿:goldensun  
這篇文章主要介紹了MySQL中的NULL值的相關(guān)知識,是MySQL入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下

我們已經(jīng)看到使用WHERE子句的SQL SELECT命令來從MySQL表獲取數(shù)據(jù)。但是,當(dāng)我們試圖給的條件比較字段或列的值為NULL,它不能正常工作。

為了處理這種情況,MySQL提供了三大運(yùn)算符

  1.     IS NULL: 此運(yùn)算符返回true,當(dāng)列的值是NULL。
  2.     IS NOT NULL: 運(yùn)算符返回true,當(dāng)列的值不是NULL。
  3.     <=> 操作符比較值(不同于=運(yùn)算符)為ture,即使兩個NULL值

涉及NULL條件是特殊的。不能使用 =NULL 或 !=NULL 尋找NULL值的列。這種比較總是告訴他們是否是真正的失敗,因?yàn)檫@是不可能的。即使是NULL=NULL失敗。

如果要查找是或不是NULL的列,請使用IS NULL或IS NOT NULL。
在命令提示符下使用NULL值:

假設(shè)一個表tcount_tbl,它包含了兩個的列stutorial_author和tutorial_count,其中一個tutorial_count為NULL 表示的值是未知的
例子:

試試下面的例子:

root@host# mysql -u root -p password;
Enter password:*******
mysql> use TUTORIALS;
Database changed
mysql> create table tcount_tbl
  -> (
  -> tutorial_author varchar(40) NOT NULL,
  -> tutorial_count INT
  -> );
Query OK, 0 rows affected (0.05 sec)
mysql> INSERT INTO tcount_tbl
  -> (tutorial_author, tutorial_count) values ('mahran', 20);
mysql> INSERT INTO tcount_tbl
  -> (tutorial_author, tutorial_count) values ('mahnaz', NULL);
mysql> INSERT INTO tcount_tbl
  -> (tutorial_author, tutorial_count) values ('Jen', NULL);
mysql> INSERT INTO tcount_tbl
  -> (tutorial_author, tutorial_count) values ('Gill', 20);

mysql> SELECT * from tcount_tbl;
+-----------------+----------------+
| tutorial_author | tutorial_count |
+-----------------+----------------+
| mahran     |       20 |
| mahnaz     |      NULL |
| Jen       |      NULL |
| Gill      |       20 |
+-----------------+----------------+
4 rows in set (0.00 sec)

mysql>

可以看到=和!=不使用NULL值,如下所示:

mysql> SELECT * FROM tcount_tbl WHERE tutorial_count = NULL;
Empty set (0.00 sec)
mysql> SELECT * FROM tcount_tbl WHERE tutorial_count != NULL;
Empty set (0.01 sec)

要找到,其中tutorial_count列是或不是NULL的記錄,查詢應(yīng)該這樣寫:

mysql> SELECT * FROM tcount_tbl 
  -> WHERE tutorial_count IS NULL;
+-----------------+----------------+
| tutorial_author | tutorial_count |
+-----------------+----------------+
| mahnaz     |      NULL |
| Jen       |      NULL |
+-----------------+----------------+
2 rows in set (0.00 sec)
mysql> SELECT * from tcount_tbl 
  -> WHERE tutorial_count IS NOT NULL;
+-----------------+----------------+
| tutorial_author | tutorial_count |
+-----------------+----------------+
| mahran     |       20 |
| Gill      |       20 |
+-----------------+----------------+
2 rows in set (0.00 sec)

PHP腳本處理NULL值:

可以使用IF ... ELSE條件準(zhǔn)備的基礎(chǔ)上操作NULL值的查詢。
例子:

下面的示例tutorial_count從外部,然后它與可在表中的值進(jìn)行比較。

<?php
$dbhost = 'localhost:3036';
$dbuser = 'root';
$dbpass = 'rootpassword';
$conn = mysql_connect($dbhost, $dbuser, $dbpass);
if(! $conn )
{
 die('Could not connect: ' . mysql_error());
}
if( isset($tutorial_count ))
{
  $sql = 'SELECT tutorial_author, tutorial_count
      FROM tcount_tbl
      WHERE tutorial_count = $tutorial_count';
}
else
{
  $sql = 'SELECT tutorial_author, tutorial_count
      FROM tcount_tbl
      WHERE tutorial_count IS $tutorial_count';
}

mysql_select_db('TUTORIALS');
$retval = mysql_query( $sql, $conn );
if(! $retval )
{
 die('Could not get data: ' . mysql_error());
}
while($row = mysql_fetch_array($retval, MYSQL_ASSOC))
{
  echo "Author:{$row['tutorial_author']} <br> ".
     "Count: {$row['tutorial_count']} <br> ".
     "--------------------------------<br>";
} 
echo "Fetched data successfully\n";
mysql_close($conn);
?>


相關(guān)文章

  • mysql實(shí)現(xiàn)隨機(jī)查詢經(jīng)驗(yàn)談

    mysql實(shí)現(xiàn)隨機(jī)查詢經(jīng)驗(yàn)談

    官方文檔中進(jìn)行說明:Order By和RAND()連用,會多次掃描表,導(dǎo)致速度變慢,下面看下一些測試詳解
    2013-10-10
  • centos6.4下mysql5.7.18安裝配置方法圖文教程

    centos6.4下mysql5.7.18安裝配置方法圖文教程

    這篇文章主要為大家詳細(xì)介紹了centos6.4下mysql5.7.18安裝配置方法圖文教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-07-07
  • Win10安裝MySQL5.7.18winX64 啟動服務(wù)器失敗并且沒有錯誤提示

    Win10安裝MySQL5.7.18winX64 啟動服務(wù)器失敗并且沒有錯誤提示

    這篇文章主要介紹了Win10安裝MySQL5.7.18winX64 啟動服務(wù)器失敗并且沒有錯誤提示,需要的朋友可以參考下
    2017-06-06
  • Linux中部署MySQL環(huán)境的四種方式圖文詳解

    Linux中部署MySQL環(huán)境的四種方式圖文詳解

    這篇文章主要介紹了Linux中部署MySQL環(huán)境的四種方式,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2023-11-11
  • MySQL8重置root賬戶密碼圖文教程超詳細(xì)講解

    MySQL8重置root賬戶密碼圖文教程超詳細(xì)講解

    root賬戶為MySQL的超級管理員用戶,擁有MySQL提供的所有權(quán)限,這篇文章主要介紹了MySQL8重置root賬戶密碼圖文教程,需要的朋友可以參考下
    2023-05-05
  • 最新MySQL高級SQL語句大全

    最新MySQL高級SQL語句大全

    這篇文章主要介紹了MySQL高級SQL語句,主要包括常用查詢知識order by按關(guān)鍵字排序的sql語句,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-06-06
  • Linux下修改MySQL編碼的方法

    Linux下修改MySQL編碼的方法

    有時候因?yàn)榫幋a需要修改mysql的編碼,windows下修改有圖文界面簡單一些,linux大家就可以參考下面的方法
    2012-04-04
  • MySQL transaction事務(wù)安全示例講解

    MySQL transaction事務(wù)安全示例講解

    這篇文章主要為大家介紹了MySQL數(shù)據(jù)庫事務(wù)安全transaction的示例講解教程,事務(wù)就是將一組操作封裝成一個執(zhí)行單元,要么一塊執(zhí)行成功,要么一塊失敗,不存在部分執(zhí)行成功的情況。事務(wù)保證了執(zhí)行的穩(wěn)定性,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步
    2022-06-06
  • MySQL性能監(jiān)控軟件Nagios的安裝及配置教程

    MySQL性能監(jiān)控軟件Nagios的安裝及配置教程

    這篇文章主要介紹了MySQL性能監(jiān)控軟件Nagios的安裝及配置教程,這里以CentOS操作系統(tǒng)為環(huán)境進(jìn)行演示,需要的朋友可以參考下
    2015-12-12
  • 詳解MySQL 數(shù)據(jù)庫范式

    詳解MySQL 數(shù)據(jù)庫范式

    這篇文章主要介紹了詳解MySQL 數(shù)據(jù)庫范式的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)MySQL,感興趣的朋友可以了解下
    2020-11-11

最新評論