MySQL IFNULL()函式用法MySQL
阿新 • • 發佈:2019-01-10
用法說明
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 這個函式,你瞭解它的作用嗎?