database - 使用自动递增主键将 csv 导入 sqlite

标签 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”,我会收到同样的错误。 当我在每行的第一个逗号前添加随机数时,我没有得到任何错误。但是,我需要使用的实际数据集可能要大得多,因此,我不能简单地手动为每个条目添加一个唯一的主键。我真的很感激这方面的一些帮助

最佳答案

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

导入一个没有该列的临时表,然后复制数据:

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

关于database - 使用自动递增主键将 csv 导入 sqlite,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15994231/

相关文章:

php - 通过我的代码创建/更新/删除还是在数据库中手动操作?

java - mybatis 映射器 xml : The content of element type "mapper" must match

database - 多个值的结果子查询 - SQL

java - 对大型 csv 文件进行快速排序

python - 如何将对象成员变量的值写入 csv 行?

Android 2.3.3 spinner 自动排序

php - Laravel 奇怪的 PDO fetchMode 问题

ruby - 从哈希创建 CSV

java - 为什么插入数据时小数点会被去掉? SQLite(Android 开发)

android - 我必须使用 _ID 作为 SQlite 主键吗?它必须是 INT 吗? (安卓开发)