首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >HeidiSQL导入csv空字段

HeidiSQL导入csv空字段
EN

Stack Overflow用户
提问于 2012-09-07 21:25:14
回答 2查看 8.1K关注 0票数 7

我想使用HeidiSQL将csv文件导入到我的MySQL数据库中。

但是我的一些字段是空的。

我该怎么做才能让HeidiSQL知道这些空值必须被视为空值?

csv文件示例(最后两个字段未知):

代码语言:javascript
复制
    NULL;Students Corner;437452182;;

创建命令:

代码语言:javascript
复制
    CREATE  TABLE `db`.`customers` (
         `company_id` INT NOT NULL AUTO_INCREMENT ,
         `company_name` VARCHAR(40) NULL ,
         `company_number` INT NULL ,
         `company_vat` INT NULL ,
         `company_zip` INT NULL,
    PRIMARY KEY (`company_id`) );

我得到以下错误:

代码语言:javascript
复制
    Incorrect integer value: '' for column 'company_id' at row 1 */
    Incorrect integer value: '' for column 'company_vat' at row 1 */
    Incorrect integer value: '' for column 'company_zip' at row 1 */
    etc
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2012-09-07 22:29:05

如果通过在每个空字段中写入\N而不是写入NULL来解决此问题!

票数 7
EN

Stack Overflow用户

发布于 2012-09-07 22:19:50

您可以使用LOAD DATA INFILE查询将CSV文件导入MySQL。

在您的例子中,您应该编写如下代码:

代码语言:javascript
复制
LOAD DATA INFILE filename.txt
INTO TABLE customers
FIELDS TERMINATED BY ';'
LINES TERMINATED BY '\n'
(@id, @name, @number, @vat, @zip)
SET
  company_id     = (CASE WHEN @id='' THEN NULL ELSE @id END),
  company_name   = (CASE WHEN @name='' THEN NULL ELSE @name END),
  company_number = (CASE WHEN @number='' THEN NULL ELSE @number END),
  company_vat    = (CASE WHEN @vat='' THEN NULL ELSE @vat END),
  company_zip    = (CASE WHEN @zip='' THEN NULL ELSE @zip END)

(您可能需要根据行尾标记等进行调整,但这应该非常接近您的需要)

票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/12319023

复制
相关文章

相似问题

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