当前位置:  开发笔记 > 数据库 > 正文

如何从查询SQL Server 2008的结果中删除"NULL"

如何解决《如何从查询SQLServer2008的结果中删除"NULL"》经验,为你挑选了2个好方法。

我有一个包含59列和超过17K行的表.NULL在一些列中有很多行.

我想删除,NULL以便查询返回一个空('')而不是一个NULL.

我可以运行所有替换一些更新的功能NULL''

使用SQL Server 2008R2 Management Studio.

UPDATE my_table
SET column_1 = REPLACE (column_1,NULL,'')

但这需要永远做到所有59列!

什么是诀窍,团队?



1> Akshey Bhat..:

使用isnull函数.如果在列中找到null,则返回指定的值

Select isnull(col1,'')



2> Erwin Brands..:

使用SQL标准COALESCE:

UPDATE my_table
SET    column_1 = COALESCE(column_1,'')
     , column_2 = COALESCE(column_2,'')
     ...
WHERE  column_1 IS NULL OR
       column_2 IS NULL OR
       ...                  -- avoid empty updates
;

然后使用ALTER TABLE ...NOT NULL所有不具有NULL的列添加约束以禁止重新引入NULL值.

不要使用ISNULL,这COALESCE在一些RDBMS中基本上是标准的重复- 而在其他RDBMS中不可用.(嗯,有细微的差别,请阅读手册了解详情或更多细节.)

当然,空字符串('')仅对字符串类型有效.例如,不适用于数字类型.

推荐阅读
跟我搞对象吧
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有