# create sqlite database called mydb.sqlite
# import data from 'employees.csv' into a SQLite table called 'employees'
# unfortunately, sqlite assumes all fields are text fields
$ sqlite3 mydb.sqlite
sqlite> .mode csv
sqlite> .import employees.csv employees
sqlite> .quit
6条答案
按热度按时间neekobn81#
CSV文件没有数据类型;一切都是一根弦。
要将一列中的所有值转换为数字,请使用以下代码:
drkbr07n2#
当导入csv文件时,SQLite假设所有的字段都是文本字段。所以你需要执行一些额外的步骤来设置正确的数据类型。
但是,据我所知,您不能使用
ALTER TABLE
语句修改SQLite中的列。相反,您需要重命名表,创建新表,并将数据复制到新表中。https://www.techonthenet.com/sqlite/tables/alter_table.php
因此,假设我有一个employees.csv文件,我想导入到SQLite数据库与正确的数据类型。
首先,创建名为
mydb.sqlite
的SQLite数据库,并将employees.csv
导入名为employees
的SQLite表。现在,数据被导入为文本,让我们首先从数据库中获取
employees
模式并将其保存到employees.sql
中,我们可以使用它来创建一个新脚本,该脚本将重命名表,创建一个新表,并将数据复制到新表中。现在,您应该拥有具有以下模式的employees.sql:
现在让我们创建一个名为alterTable.sql的SQL字段,它将重命名表、创建一个新表并将数据复制到新表中。
更改表.sql
最后,我们可以在
alterTable.sql
中执行SQL并删除旧的重命名表此时,导入的员工数据应该具有正确的数据类型,而不是默认的文本字段。
如果你这样做,你不必担心csv文件中的标题被导入为数据。其他方法可能需要你在导入csv文件之前或之后删除标题。
b0zn9rqh3#
您只需要首先使用正确的类型创建表,然后CSV导入将保留此类型,因为表已经存在。
下面是一个示例:
如果您需要删除导入的标题行,请在导入后使用类似以下的命令:
或者在您已经多次导入同一个表的情况下使用此函数:
最后你可以像这样检查正确的导入:
lb3vh1jj4#
在SQLite中,您无法更改列的类型关联。因此,您应该先将表
create
,然后将CSV文件.import
到表中。如果CSV文件具有标题,则在导入时将其视为数据。您可以在导入前删除标题(在CSV文件中),或在导入后删除标题(在表中)。由于typeof
所有标题字段都将是TEXT
,因此您可以在某些列具有数值类型关联的表中轻松找到此标题。dluptydi5#
1.将CSV文件导入SQLite。
1.转到数据库结构并选择导入的CSV文件
1.从选项卡中选择修改表
1.选择字段1并将名称更改为所需的列名称。
1.接下来,从下拉菜单中选择所需的数据类型。现在,您可以根据正在处理的数据从文本更改为整数或数值
5ktev3wc6#
我使用的是sqlite 3.39.4,我会做如下操作:
按照上面的建议,创建一个具有正确类型的新表“newtable”,然后从“mycsvtable. csv”导入数据,键入
如果csv中有标题,--skip 1将避开第一行