sql-server – 检查SQL Server 2005 XML字段是否为空

我这样做了:
Delete FROM MyTable WHERE ScopeValue = "" 
Delete FROM G_Scope WHERE ScopeValue is ''
Delete FROM G_Scope WHERE ScopeValue = empty
Delete FROM G_Scope WHERE ScopeValue is empty

我想用xml字段删除所有行(不可为空),其中ScopeValue列有空条目表示零字符.

有谁知道?

解决方法

试试这个:
DELETE FROM dbo.G_Scope WHERE ScopeValue IS NULL

如果不包含任何值,sql Server列将为NULL.

另一种可能性是XML不是NULL,而是包含一个空字符串作为其值.为此,请使用此命令:

-- The DATALENGTH of an empty XML column is 5
SELECT * FROM dbo.G_Scope WHERE DATALENGTH(ScopeValue) = 5

这会显示您感兴趣的行吗?

相关文章

SELECT a.*,b.dp_name,c.pa_name,fm_name=(CASE WHEN a.fm_n...
if not exists(select name from syscolumns where name=&am...
select a.*,pano=a.pa_no,b.pa_name,f.dp_name,e.fw_state_n...
要在 SQL Server 2019 中设置定时自动重启,可以使用 Window...
您收到的错误消息表明数据库 'EastRiver' 的...
首先我需要查询出需要使用SQL Server Profiler跟踪的数据库标...