Jaw*_*ria 16 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));
Run Code Online (Sandbox Code Playgroud)
这是.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
Run Code Online (Sandbox Code Playgroud)
这是我收到的错误:
sqlite> .mode csv
sqlite> import allegiances.csv Allegiance;
Error: datatype mismatch
Run Code Online (Sandbox Code Playgroud)
如果我在每行中的第一个逗号之前有"null",则会收到相同的错误.当我在每行的第一个逗号之前添加随机数时,我没有收到任何错误.但是,我需要使用的实际数据集可能要大得多,因此,我不能简单地为每个条目手动添加唯一的主键.我真的很感激这方面的一些帮助
CL.*_*CL. 24
CSV文件中的空字段只是一个空字符串,对于INTEGER PRIMARY KEY列无效.
导入没有该列的临时表,然后复制数据:
INSERT INTO Allegiance(CharacterID, Title) SELECT * FROM TempTable;
Run Code Online (Sandbox Code Playgroud)