首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >SQL Server导入向导将NULL视为文本字符串“NULL”

SQL Server导入向导将NULL视为文本字符串“NULL”
EN

Stack Overflow用户
提问于 2013-06-28 02:55:50
回答 3查看 18.6K关注 0票数 4

当我尝试将.csv逗号分隔的平面文件导入到Microsoft SQL server 2008R2 64-bit instance中时,对于string列,原始数据中的NULL变为文字字符串"NULL",并且在numeric列中收到导入错误。有人能帮帮忙吗?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2013-06-28 02:58:15

将数据放入临时表中,然后使用SQL代码插入到生产表中。

代码语言:javascript
运行
复制
update table1
set field1 = NULL
where field1 = 'null'

或者如果你想做很多领域

代码语言:javascript
运行
复制
update table1
    set field1 = case when field1 = 'null' then Null else Field1 End
      , field2 = case when field2 = 'null' then Null else Field2 End
      , field3 = case when field3 = 'null' then Null else Field3 End
票数 3
EN

Stack Overflow用户

发布于 2015-07-07 00:18:28

接吻

对其进行预处理,将所有"NULL“替换为"”。

即.csv文件将具有

代码语言:javascript
运行
复制
,,

而不是

代码语言:javascript
运行
复制
NULL,NULL,

似乎为我做了这件事。

票数 10
EN

Stack Overflow用户

发布于 2014-09-22 20:24:11

除了HLGEM的回答,我动态地做了这件事,我将所有列类型都加载到这里的临时表中,然后这样做:

代码语言:javascript
运行
复制
DECLARE @sql VARCHAR(MAX) = '';
SELECT @sql = CONCAT(@sql, '
    UPDATE [staging].[',[TABLE_NAME],']
    SET [',[COLUMN_NAME],'] = NULL
    WHERE [',[COLUMN_NAME],'] = ''NULL'';
    ')
FROM INFORMATION_SCHEMA.COLUMNS
WHERE [TABLE_SCHEMA] = 'staging' 
    AND [TABLE_NAME] IN ('MyTableName');
SELECT @sql;
EXEC(@sql);

然后执行以下操作:

代码语言:javascript
运行
复制
INSERT INTO [dbo].[MyTableName] ([col1], [col2], [colN])
SELECT [col1], [col2], [colN]
FROM [staging].[MyTableName]
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/17351099

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档