使用自动增量主键将csv导入sqlite

时间:2013-04-13 23:58:18

标签: database csv sqlite

我正在尝试在sqlite中创建一个表,该表从csv文件中获取数据并将自动增量主键添加到第一列。 这是我试图将数据插入的表:

DROP TABLE IF EXISTS Allegiance;
CREATE TABLE Allegiance (
  AllegianceID INTEGER PRIMARY KEY AUTOINCREMENT,
  CharacterID INTEGER,
  Title TEXT,
  FOREIGN KEY (CharacterID) REFERENCES Characters(CharacterID));

以下是.csv文件中的数据

, 3, King of the North
, 14, King of the Andals and the First Men
, 15, Lord of Dragonstone
, 26, Khaleesi
, 35, Lord Reaper of Pyke

这是我收到的错误:

sqlite> .mode csv
sqlite> import allegiances.csv Allegiance;
Error: datatype mismatch

如果我在每行的第一个逗号之前有“null”,则会收到相同的错误。 当我在每行的第一个逗号之前添加随机数时,我没有收到任何错误。但是,我需要使用的实际数据集可能要大得多,因此,我不能简单地为每个条目手动添加唯一的主键。我真的很感激这方面的帮助

2 个答案:

答案 0 :(得分:20)

CSV文件中的空字段只是一个空字符串,对INTEGER PRIMARY KEY列无效。

导入没有该列的临时表,然后使用以下内容复制数据:

INSERT INTO Allegiance(CharacterID, Title) SELECT * FROM TempTable;

答案 1 :(得分:1)

您可以在文本文件中添加包含主键的列,然后将其导入。 注意:如果在第一列上出现该错误,请确保您的文件没有BOM。如果它有BOM(文件开头的3个字节),它将在第一行失败。

1:INSERT失败:数据类型不匹配

>     drop table words ;
>     CREATE TABLE words (id INTEGER PRIMARY KEY AUTOINCREMENT, name COLLATE NOCASE, rank INT);
>     .import file.txt words

1|a|0
2|b|0
3|c|0
4|d|0
5|e|0
6|f|0
7|g|0