首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用自动递增主键将csv导入sqlite

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

Stack Overflow用户
提问于 2013-04-14 07:58:18
回答 2查看 18K关注 0票数 19

我正在尝试在sqlite中创建一个表,该表从csv文件中获取数据,并在第一列中添加一个自动递增的主键。下面是我尝试向其中插入数据的表:

代码语言:javascript
复制
DROP TABLE IF EXISTS Allegiance;
CREATE TABLE Allegiance (
  AllegianceID INTEGER PRIMARY KEY AUTOINCREMENT,
  CharacterID INTEGER,
  Title TEXT,
  FOREIGN KEY (CharacterID) REFERENCES Characters(CharacterID));

下面是.csv文件中的数据

代码语言:javascript
复制
, 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

这是我收到的错误:

代码语言:javascript
复制
sqlite> .mode csv
sqlite> import allegiances.csv Allegiance;
Error: datatype mismatch

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

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-04-14 18:50:01

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

导入到不包含该列的临时表中,然后使用以下命令复制数据:

代码语言:javascript
复制
INSERT INTO Allegiance(CharacterID, Title) SELECT * FROM TempTable;
票数 30
EN

Stack Overflow用户

发布于 2018-04-02 03:29:09

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

1:插入失败:数据类型不匹配

代码语言:javascript
复制
>     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
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/15994231

复制
相关文章

相似问题

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