Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/sql/86.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/7/sql-server/25.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Sql 更新所有需要将“NULL”作为字符串更新为DB NULL的行_Sql_Sql Server_Tsql - Fatal编程技术网

Sql 更新所有需要将“NULL”作为字符串更新为DB NULL的行

Sql 更新所有需要将“NULL”作为字符串更新为DB NULL的行,sql,sql-server,tsql,Sql,Sql Server,Tsql,是否有一种方法可以更改SQL中某个特定值的所有匹配项,而不考虑列 我有一个约200列的表,它是从文本文件导入的。空值作为字符串值“NULL”出现在表中的大多数列中。有没有办法将这些值转换为真正的空值?我希望避免在每个单独的列上使用更新。单个更新可能不会太痛苦: update t set col1 = nullif(col1, 'NULL'), col2 = nullif(col2, 'NULL'), . . .; 通过查询字符串列的SCHEMA.colu

是否有一种方法可以更改SQL中某个特定值的所有匹配项,而不考虑列


我有一个约200列的表,它是从文本文件导入的。空值作为字符串值“NULL”出现在表中的大多数列中。有没有办法将这些值转换为真正的空值?我希望避免在每个单独的列上使用更新。单个更新可能不会太痛苦:

update t
    set col1 = nullif(col1, 'NULL'),
        col2 = nullif(col2, 'NULL'),
        . . .;

通过查询字符串列的SCHEMA.column或类似信息,您可以在SQL或电子表格中生成代码。

使用并为所有匹配行设置null,这是一种更快速、更有效的方法。

如果不对每个列进行更新,则无法完成此操作


有一些快捷方式可以编写这样的更新,比如右键单击>脚本作为。。。或者动态sql,但到目前为止,这不是您所要求的。

您可以使用动态sql构建更新脚本

声明@update\u sql NVARCHARMAX=N

SELECT 
    @update_sql = CONCAT(@update_sql, N',
    mt.', c.name, N' = NULLIF(mt.', c.name, N', ''NULL'')')    
FROM
    sys.columns c
WHERE
    c.object_id = OBJECT_ID(N'dbo.MyTable')
    AND c.collation_name IS NOT NULL; -- easy way to make sure you're only looking at columns that can hold test data. 

SET @update_sql = CONCAT(N'
UPDATE mt SET',
STUFF(@update_sql, 1, 1, ''), N'
FROM 
    dbo.MyTable mt;')

PRINT(@update_sql);
您将得到如下格式的输出

UPDATE mt SET
    mt.column_9 = NULLIF(mt.column_9, 'NULL'),
    mt.column_10 = NULLIF(mt.column_10, 'NULL'),
    mt.column_11 = NULLIF(mt.column_11, 'NULL'),
    mt.column_14 = NULLIF(mt.column_14, 'NULL'),
...
    mt.column_165 = NULLIF(mt.column_165, 'NULL'),
    mt.column_166 = NULLIF(mt.column_166, 'NULL'),
    mt.column_167 = NULLIF(mt.column_167, 'NULL'),
    mt.column_168 = NULLIF(mt.column_168, 'NULL')
FROM 
dbo.MyTable mt;

注意。。。打印命令限制为8000个ASCII字符和4000个unicode字符。因此,如果您注意到输出脚本被截断,请发回,我有一个很长的打印过程可以绕过该限制。

修复文件并重新导入。使用您使用的数据库标记您的问题。这些文件是通过python脚本创建的。这是72个csv文件,我还不能成功地将NaN值从python导入SQL。