MySQL IFNULL()函數用法MySQL 自帶函數


轉自:http://www.nowamagic.net/academy/detail/3203050

用法說明

1 IFNULL(expr1,expr2)

如果 expr1 不是 NULL,IFNULL() 返回 expr1,否則它返回 expr2。

IFNULL()返回一個數字或字符串值,取決於它被使用的上下文環境。

我們先舉一些例子:

1 mysql> SELECT IFNULL(1,0);
2 +-------------+
3 | IFNULL(1,0) |
4 +-------------+
5 |           1 |
6 +-------------+
7 1 row in set
  •  
    由於 expr1 是 1,不為 NULL,所以函數返回 1. 我們可以再試下,如果讓 expr1 為 NULL,是否能返回第二個參數呢? 不妨讓 expr1 = 1/0, 由於除數為0,結果就為 NULL 了。
1 mysql> SELECT IFNULL(1/0,'NowaMagic');
2 +-------------------------+
3 | IFNULL(1/0,'NowaMagic') |
4 +-------------------------+
5 | NowaMagic               |
6 +-------------------------+
7 1 row in set

前面的參數為 NULL,就返回第二個參數 NowaMagic 了。

  •  
    這個函數不難理解,為什么要介紹這個函數呢?這是為了后面講述 MySQL 下的高級黑客技術做的基礎知識准備,你可以先試着理解這么一句 hack SQL:
1 UPDATE table SET views = '1' WHERE id = -2441 OR (ORD(MID((SELECT IFNULL(CAST(FirstName AS CHAR),0x20) FROM nowamagic.`tb2` ORDER BY id LIMIT 1,1),2,1))>112)#

里面用到了 IFNULL 這個函數,你了解它的作用嗎?


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM