MySQL中的isnull、ifnull和nullif函数用法

isnull(expr)

如expr为null,那么isnull()的返回值为1,否则返回值为0。

mysql>select isnull(1+1);

->0

mysql>select isnull(1/0);

->1

使用=的null值对比通常是错误的。

isnull()函数同is null比较操作符具有一些相同的特性。请参见有关is null 的说明。

ifnull(expr1,expr2)

假如expr1不为NULL,则IFNULL()的返回值为expr1; 否则其返回值为expr2。IFNULL()的返回值是数字或是字符串,具体情况取决于其所使用的语境。

mysql>SELECT IFNULL(1,0);

->1

mysql>SELECT IFNULL(NULL,10);

->10

mysql>SELECT IFNULL(1/0,10);

->10

mysql>SELECT IFNULL(1/0,‘yes‘);

->‘yes‘

ifnull(expr1,expr2)的默认结果值为两个表达式中更加“通用”的一个,顺序为STRING、REAL或INTEGER。假设一个基于表达式的表的情况,或MySQL必须在内存储器中储存一个临时表中IFNULL()的返回值:

CREATE TABLE tmp SELECT IFNULL(1,‘test‘) AS test;

在这个例子中,测试列的类型为 CHAR(4)。

nullif(expr1,expr2)

如果expr1=expr2成立,那么返回值为NULL,否则返回值为expr1。这和

CASE WHEN expr1=expr2 THEN NULL

ELSE

expr1

END相同。

mysql>SELECT NULLIF(1,1);

->NULL

mysql>SELECT NULLIF(1,2);

->1

如果参数不相等,则MySQL两次求得的值为expr1 。

来源: https://jingyan.baidu.com/article/6b182309516bc5ba58e159f0.html

一、IF函数 
表达式:IF(expr1,expr2,expr3) 
满足条件expr1即条件expr1返回true 
则expr2否则就是expr3 返回false 
作为排序条件使用时 放在order by 后 
eg: 
1. SELECT IF(1=1,2,3); 则输出2 
2.SELECT IF(1=2,2,3);则输出3 
select * from test_table order by if(ISNULL(idcard),1,0) 
二、IFNULL函数 
表达式:IFNULL(expr1,expr2) 
如果expr1值为NULL,则输出expr2 
如果expr1值不为空则输出expr1本身

eg: 
1.SELECT IFNULL(null,”2”);则输出2 
2.SELECT IFNULL(3,”2”);则输出3

三、is not null函数 
select * from test where name is not null; 
四、isnull(expr) 的用法: 
如expr 为null,那么isnull() 的返回值为 1,否则返回值为 0。

来源: http://blog.csdn.net/cc_yy_zh/article/details/52700478

来自为知笔记(Wiz)

时间: 2025-01-10 17:17:12

MySQL中的isnull、ifnull和nullif函数用法的相关文章

MySQL NULLIF函数用法

MySQL NULLIF函数以及如何使用它来防止查询中的除以零错误,NULLIF函数是接受2个参数的控制流函数之一.如果第一个参数等于第二个参数,则NULLIF函数返回NULL,否则返回第一个参数. 1,NULLIF语法结构 NULLIF(expression_1,expression_2); 2,举例用法 SELECT NULLIF(1,1); SELECT NULLIF(1,2); SELECT NULLIF('MySQL NULLIF','MySQL NULLIF'); NULLIF函数来

MySQL中CONCAT、CONCAT_WS和GROUP_CONCAT函数

一.CONCAT()函数CONCAT()函数用于将多个字符串连接成一个字符串.使用数据表Info作为示例,其中SELECT id,name FROM info LIMIT 1;的返回结果为+----+--------+| id | name   |+----+--------+|  1 | BioCyc |+----+--------+1.语法及使用特点:CONCAT(str1,str2,-)                       返回结果为连接参数产生的字符串.如有任何一个参数为NULL

[转] mysql中insert into select和create select用法

在mysql中可以把已经存在的表直接通过命令复制为另一个表 方法1:create table mmm select * from bbb; 注意:这条命令要求mmm这个表在数据库中不存在这条命令可以创建新表mmm并且bbb中的表结构以及数据和mmm完全一样,也可以导出部分字段 create table mmm select 字段1,字段2 from bbb; 方法2:insert into mmm select * bbb; 这条语句和上一条语句实现同样的功能,只是要求mmm表必须在数据库中存在

mysql中比较实用的几个函数

1.曾有这样的需求: 可以使用如下函数: 语法:FIND_IN_SET(str,strlist). 定义: 1. 假如字符串str在由N子链组成的字符串列表strlist中,则返回值的范围在1到N之间. 2. 一个字符串列表就是一个由一些被‘,’符号分开的自链组成的字符串. 3. 如果第一个参数是一个常数字符串,而第二个是typeSET列,则FIND_IN_SET()函数被优化,使用比特计算. 4. 如果str不在strlist或strlist为空字符串,则返回值为0. 5. 如任意一个参数为N

JavaScript中bind、call、apply函数用法详解

在给我们项目组的其他程序介绍 js 的时候,我准备了很多的内容,但看起来效果不大,果然光讲还是不行的,必须动手.前几天有人问我关于代码里 call() 函数的用法,我让他去看书,这里推荐用js 写服务器的程序猿看<javascript编程精粹> 这本书,crockford大神果然不是盖的.之后我在segmentfault上又看到了类似的问题,那边解答之后干脆这里记一笔. 首先,关于 js 定义类或对象的方法,请参看w3school 的这里的这里,写的非常详细和清晰,我不再赘言了. 为了介绍 b

Javascript中bind、call、apply函数用法

js 里函数调用有 4 种模式:方法调用.正常函数调用.构造器函数调用.apply/call 调用. 同时,无论哪种函数调用除了你声明时定义的形参外,还会自动添加 2 个形参,分别是 this 和arguments. arguments 不涉及到上述 3 个函数,所以这里只谈 this.this 的值,在上面 4 中调用模式下,分别会绑定不同的值.分别来说一说: 方法调用: 这个很好理解,函数是一个对象的属性,比如 var a = { v : 0, f : function(xx) { this

mysql中AES_ENCRYPT、AES_DNCRYPT及CONVERT的用法

这两天在弄公司的服务端项目的时候,发现mysql比较实用的3个函数,在这里给大家分享一下. 1.AES_ENCRYPT函数,这个函数的使用场景是对一些安全性要求比较高的数据使用AES加密,语法为: AES_ENCRYPT(str,key),其中第一个参数表示要加密的数据,第二参数是对应的key. 2.AES_DECRYPT函数,这个函数是与AES_DECRYPT对应的一个函数,用于解密经过AES_DNCRYPT加密的数据,语法为:AES_DNCRYPT(str,key). 3.CONVERT函数

VC++程序中加入自定义声音(PlaySound函数用法)

VC++编程中,我们可以为自己的程序加入音乐,比如当我们按下一个按钮时或者启动程序时,播放一小段音乐. 该功能用到函数: BOOL PlaySound(LPCSTR pszSound, HMODULE hwnd,DWORD fdwSound); 参数定义: 参数pszSound是指定了要播放声音的字符串(一般是绝对路径,如果把声音文件拷到可执行文件所在路径就可以直接用声音文件名),该参数可以是WAVE文件的名字,或是WAV资源的名字,或是内存中声音数据的指针,或是在系统注册表WIN.INI中定义

js中的join(),reverse()与 split()函数用法解析

<script> /* * 1:arrayObject.reverse() * 注意: 该方法会改变原来的数组,而不会创建新的数组. * 2:arrayObject.join() * 注意:join() 方法用于把数组中的所有元素放入一个字符串. * 元素是通过指定的分隔符进行分隔的. * 指定分隔符方法join("#");其中#可以是任意 * 3:stringObject.split(a,b)这是它的语法 * 方法:用于把一个字符串分割成字符串数组. * a是必须的决定个