为SQL中所有可为空的列设置NULL

问题描述

我遇到以下问题:早期版本的数据库使用值”而不是NULL。如果列可以为空,我现在必须将这些值存在的所有位置都转换为NULL。

我尝试了以下代码:

{{'Instagram': [datetime.time(4,28,5,322902),datetime.time(6,29,7,122295),30,8,885536),datetime.time(7,31,10,637131datetime.time(7,36,19,449087)]},{'Twitter':[datetime.time(5,37,21,179529),datetime.time(5,38,22,942552),datetime.time(20,13,629529),14,33,387693)]},{'Facebook':[datetime.time(17,15,35,188039),datetime.time(19,16,955703),datetime.time(21,387693)]}}

在运行时,它为每一列给出以下错误:“无效的对象名称'column_name'。

如果有人能为我找到错误,我将非常感激。

解决方法

如果查看生成的查询,则会发现查询不正确。

您需要更改将值提取到游标中的顺序。

FETCH NEXT FROM cursor_setnull INTO
    @curcolumn,@curtable;

应该是

FETCH NEXT FROM cursor_setnull INTO
    @curtable,@curcolumn;
,

我将不使用CURSOR,而是使用一些显式事务来批量处理全部事务。我假定 SQL Server 2017+,因为当我问您使用的是哪个版本时,缺少回复:

DECLARE @SQL nvarchar(MAX),@CRLF nchar(2) = NCHAR(13) + NCHAR(10);

DECLARE @Delimiter nvarchar(10) = N',' + @CRLF + N'    ' 

SET @SQL = STUFF((SELECT @CRLF + N'BEGIN TRANSACTION;' + @CRLF +
                         N'    UPDATE ' + QUOTENAME(s.[name]) + N'.' + QUOTENAME(t.[name]) + @CRLF + 
                         N'    SET ' + (SELECT STRING_AGG(QUOTENAME(c.[name]) + N' = CASE ' + QUOTENAME(c.[name]) + N' WHEN '''' THEN NULL ELSE '+ QUOTENAME(c.[name]) + N' END',@Delimiter) WITHIN GROUP (ORDER BY c.column_id)
                                        FROM sys.columns c
                                             JOIN sys.types ct ON c.system_type_id = ct.system_type_id
                                        WHERE c.object_id = t.object_id
                                          AND ct.[name] IN ('varchar','nvarchar','char','nchar')
                                          AND c.is_nullable = 1
                                          AND c.is_computed = 0) + N';' + @CRLF + 
                        N'COMMIT TRANSACTION'
                  FROM sys.schemas s
                       JOIN sys.tables t ON s.schema_id = t.SCHEMA_ID
                  WHERE EXISTS (SELECT 1
                                FROM sys.columns c
                                     JOIN sys.types ct ON c.system_type_id = ct.system_type_id
                                WHERE c.object_id = t.object_id
                                AND ct.[name] IN ('varchar','nchar')
                                AND c.is_nullable = 1
                                AND c.is_computed = 0)
                  ORDER BY s.schema_id,t.object_id
                  FOR XML PATH(N''),TYPE).value('(./text())[1]','nvarchar(MAX)'),1,2,N'');

PRINT @SQL; --Your best friend

--EXEC sys.sp_executesql @SQL; --Uncomment to run dynamic statement.

相关问答

错误1:Request method ‘DELETE‘ not supported 错误还原:...
错误1:启动docker镜像时报错:Error response from daemon:...
错误1:private field ‘xxx‘ is never assigned 按Alt...
报错如下,通过源不能下载,最后警告pip需升级版本 Requirem...