Mysql字段為null的加減乘除運(yùn)算方式
Mysql字段為null的加減乘除運(yùn)算
數(shù)據(jù)庫(kù)表test_table
如下查詢:
select id, total, used, (total - used) as have from test_table;
查詢結(jié)果:
解決辦法
使用IFNULL 函數(shù)來解決NULL值問題
select id, IFNULL(total,0) as total, IFNULL(used,0) as used, (IFNULL(total,0) - IFNULL(used,0)) as have from test_table;
查詢結(jié)果:
數(shù)據(jù)庫(kù)關(guān)于null不參與運(yùn)算的坑
舉個(gè)例子:(閱讀時(shí):請(qǐng)記住這個(gè)字段以及它的值 )
如果數(shù)據(jù)庫(kù)表里字段值為 null 時(shí),那么在寫sql語句用這個(gè)值去做比較運(yùn)算時(shí)(一般看見 null 或者參數(shù)類型為 string 時(shí) 也沒有人去做加減乘除),除了 is nl 或者 is not nlll 沒有其他操作, 有時(shí) 字段類型 為 string ,值為 "2" 時(shí), 會(huì)用 <> 如果數(shù)據(jù)庫(kù)表里字段值為 null 時(shí),那么在寫sql語句用這個(gè)值去做比較運(yùn)算時(shí)(一般看見 null 或者參數(shù)類型為 string 時(shí) 也沒有人去做加減乘除),除了 is null 或者 is not null 沒有其他操作, 有時(shí) 字段類型 為 string ,值為 "2" 時(shí), 會(huì)用 <> (不等于)] 判斷,這都沒問題,問題出現(xiàn)在 null 與其他值同時(shí)存在這個(gè) 當(dāng)前字段 下,那么用 <> 會(huì)造成 mysql 查詢不到數(shù)據(jù),因?yàn)?<>"2" 不會(huì)把 null 過濾出去,此時(shí) null 是參與運(yùn)算的,所以sql語句應(yīng)當(dāng)調(diào)整為 坑 is null(is not null) and 坑=“2”(坑<>“2”) 這種寫法,sql執(zhí)行之后才會(huì)是我們想要的結(jié)果。
發(fā)生場(chǎng)景
Mybatis框架的動(dòng)態(tài)sql 在寫xml映射文件時(shí) 比如: <if test=" 坑 = ‘2’ 或(坑 <> ‘2’) > 這種不實(shí)時(shí)看數(shù)據(jù)庫(kù),腦子里還想著業(yè)務(wù)需求怎么實(shí)現(xiàn)時(shí)(一心二用)
其本質(zhì)還是對(duì)于 基礎(chǔ)知識(shí) 掌握不扎實(shí),所以不斷進(jìn)步的同時(shí),也不要忘了 夯實(shí)基礎(chǔ) 個(gè)人理解: 動(dòng)態(tài)sql最強(qiáng)大的 不是它的語法和格式的優(yōu)點(diǎn),首先 它并沒有原生sql語句的可讀性高,其次 動(dòng)態(tài)sql本質(zhì)也 僅僅 就起到一個(gè)sql語句拼接的作用,它真正強(qiáng)大的點(diǎn)是 <forEach> 這個(gè)可以遍歷集合的標(biāo)簽,這是原生sql語句無法做到的事情,所以在沒有對(duì) 集合 進(jìn)行操作的情況下,盡量用原生sql去做。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
MySQL錯(cuò)誤Forcing close of thread的兩種解決方法
這篇文章主要介紹了MySQL錯(cuò)誤Forcing close of thread的兩種解決方法,需要的朋友可以參考下2014-11-11Canal監(jiān)聽MySQL的實(shí)現(xiàn)步驟
本文主要介紹了Canal監(jiān)聽MySQL的實(shí)現(xiàn)步驟,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08MySQL命令行方式進(jìn)行數(shù)據(jù)備份與恢復(fù)
本文主要介紹了MySQL命令行方式進(jìn)行數(shù)據(jù)備份與恢復(fù),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08mysql外鍵(Foreign Key)介紹和創(chuàng)建外鍵的方法
這篇文章主要介紹了mysql外鍵(Foreign Key)命令和添加外鍵方法,需要的朋友可以參考下2014-02-02