我有一个包含59列和超过17K行的表.NULL
在一些列中有很多行.
我想删除,NULL
以便查询返回一个空(''
)而不是一个NULL
.
我可以运行所有替换一些更新的功能NULL
有''
?
使用SQL Server 2008R2 Management Studio.
UPDATE my_table SET column_1 = REPLACE (column_1,NULL,'')
但这需要永远做到所有59列!
什么是诀窍,团队?
使用isnull函数.如果在列中找到null,则返回指定的值
Select isnull(col1,'')
使用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中不可用.(嗯,有细微的差别,请阅读手册了解详情或更多细节.)
当然,空字符串(''
)仅对字符串类型有效.例如,不适用于数字类型.