sql中isnull函数的用法(sql中isnull是什么意思)

http://www.itjxue.com  2023-01-29 07:50  来源:未知  点击次数: 

SQL中isnull 和 as 的用法

isnull(a,b) 的意思是,判断a是否是null值,如果是则取b,如果不是null则取a值

as 在这里是给这一个自定义列顶一个了一个名称

所以总起来说,意思是:

如果a是null,则取b,如果a不是null,则取a

如果a,b都是null,则取c,

最终的结果,作为一个新列D,出现在查询结果中

sqlserver?isnull在数据库查询中的应用

isnull在数据库查询中的应用,特别是再语句连接的时候需要用到

比如连接时候,某个字段没有值但是又要左连接到其他表上

就会显示空,

isnull可以判断是否是NULL,如果是给个默认值

isnull("字段名","默认的数据")

SqlServer中的null值与IsNull函数

NULL

值的三大特点,分别是:1)NULL值不参加统计;2)NULL值不进入计算表达式;3)不能与其它值进行比较。

所谓NULL值不参加统计

在使用统计函数时,凡是涉及到

NULL值的都会被忽视掉(用词可能不准确),不要以为这不重要,其实在某些地方这是很重要的。而

NULL值不进入计算也就是说在进行数据之间的统计计算时,若有为

NULL值的项,那么它是不进入即不参加计算的。这也是一个不容忽视的问题。这即使在生活中也是常见的。就好比如说一个人的奖金为NULL值(没有录入数据或其它的原因,不做探讨),而他的基本工资总不会为

吧?!(如果为0,早就被T了),月末算总工资的时候把基本工资加上奖金,而若是奖金为

NULL值,总工资

=

基本工资

+

奖金(NULL),那么当此种情况发生时,总工资

=

基本工资

肯定的回答是:不等于。因为奖金为

NULL值,NULL值代表具体的什么值?都不知道。而不知道NULL值到底是多少,那么又怎么能进行计算呢?所以总工资等于

NULL

的,也是不确定的。这样,还有员工敢在公司吗?万一你来个总工资的

NULL

为真的空了,那还做什么工作啊?!这就涉及到一个强制转换的问题,即把

NULL值强制转换为

,让其具备业务意义。而强制转换的关键字就是

IS

,语法即

IS

NULL;这样就可以进行涉及

NULL值的计算了。

不过

NULL值也不是对所有的统计函数都有影响。一般来说。统计平均值(AVG)时,

NULL值是一定会有影响的;统计最小值(MIN)时,

NULL值是可能会对

MIN

有影响,在我认为是有点随机性质;统计最大值(MAX)或统计和(NULL)时,NULL值是对其完全没有影响的。

所以又有一种说法是:null值不参加统计,不参加计算,只能用is判断。

判断Null值语句:select

*

from

where

字段

is

null;

转换null值语句:select

字段1,字段2,字段3,is

null(字段3,'某个值')

from

表;

总之,我们要认真对待

NULL值,最好在使用统计函数时,都加上

IS

NULL,以防意外出现。

sqlserver

中isnull的用法一例

数据库中有一列记录文章的访问次数。我现在要实现的功能是,每刷新一次页面。

访问次数+1。sql语句,art_count为访问次数,int类型。

update

article

set

art_count="(art_count+1)

where

art_id="3

但如果art_count为NULL,则不起作用。

如果是oracle用decode可以很容易的实现此功能。sqlserver中如何实现类似的功能呢?

sqlserver中有一个函数isnull,此函数有两个参数isnull(p1,p2)其用法是如果p1为null,则用p2代替。

此函数类似oracle的nvl。例如

SELECT

AVG(ISNULL(price,

$10.00))

FROM

titles

受到此函数的启发我这样写的sql语句

update

article

set

art_count="(isnull(vote_count,0)+1)

where

art_id="3

"

SQL isnull( )函数的用法。比如isnull(a,' ')=' '是什么意思?

isnull的返回值是,当a不为空时,返回a本身,当a为空时间返回第二个参数。isnull(a,'

')='

'这是一个布尔表达式,当a为空时表达式为真,否则为假。

SQL isnull( )函数的用法.比如isnull(a,' ')='

举个例子

表table_1中字段A有3行数据,分别是1,2,NULL

select ISNULL(A,NULL)=0 from table_1

显示结果

A

1

2

为NULL的那行数据,查询结果不是NULL,而是0

MySql中的IFNULL、NULLIF和ISNULL用法详解

今天用到了MySql里的isnull才发现他和MSSQL里的还是有点区别,现在简单总结一下:

mysql中isnull,ifnull,nullif的用法如下:

isnull(expr)

的用法:

如expr

为null,那么isnull()

的返回值为

1,否则返回值为

0。

mysql

select

isnull(1+1);

-

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

以上所述是小编给大家介绍的MySql中的IFNULL、NULLIF和ISNULL用法详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

(责任编辑:IT教学网)

更多

推荐软件水平考试文章