我想使用HeidiSQL将csv文件导入到我的MySQL数据库中。
但是我的一些字段是空的。
我该怎么做才能让HeidiSQL知道这些空值必须被视为空值?
csv文件示例(最后两个字段未知):
NULL;Students Corner;437452182;;创建命令:
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`) );我得到以下错误:
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发布于 2012-09-07 22:29:05
如果通过在每个空字段中写入\N而不是写入NULL来解决此问题!
发布于 2012-09-07 22:19:50
您可以使用LOAD DATA INFILE查询将CSV文件导入MySQL。
在您的例子中,您应该编写如下代码:
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)(您可能需要根据行尾标记等进行调整,但这应该非常接近您的需要)
https://stackoverflow.com/questions/12319023
复制相似问题