首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >合并两个SQLITE数据库的最快方法

合并两个SQLITE数据库的最快方法
EN

Stack Overflow用户
提问于 2012-02-19 21:39:54
回答 2查看 33.8K关注 0票数 16

我有3个SQLite数据库,每个数据库都有完全相同的7个表的表结构。它们是来自3台不同机器的日志转储。

我想将它们合并到一个SQLite DB中,具有非常相同的7个表,但每个表都应该包含来自所有三个DB的组合数据。因为我想在其中的3个上运行查询。最好、最快的方法是什么?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2012-02-19 21:51:52

将每个数据库导出到SQL转储,然后将转储导入到新的组合数据库中。

对于GUI,可以查看http://www.sqlite.org/cvstrac/wiki?p=ManagementTools

例如,对于SQLiteStudio,将是数据库>导出数据库:Export format:SQL > Done

使用命令行sqlite实用程序(在linux repos中可用,并且通常已经存在ootb),您可以通过以下步骤创建转储:

代码语言:javascript
复制
# starts the interactive prompt
sqlite3 my_database.sqlite

sqlite> .output my_dump.sql
sqlite> .exit

要从交互式提示符导入转储文件,请执行以下操作:

代码语言:javascript
复制
sqlite> .read export.sqlite3.sql

您也可以直接从shell导入:

代码语言:javascript
复制
cat my_dump.sql | sqlite3 my_database.sqlite
票数 7
EN

Stack Overflow用户

发布于 2016-05-10 20:25:07

这是一种合并两个具有相同结构的表的数据库的方法。我希望它能有所帮助。

代码语言:javascript
复制
import sqlite3
con3 = sqlite3.connect("combine.db")

con3.execute("ATTACH 'results_a.db' as dba")

con3.execute("BEGIN")
for row in con3.execute("SELECT * FROM dba.sqlite_master WHERE type='table'"):
    combine = "INSERT INTO "+ row[1] + " SELECT * FROM dba." + row[1]
    print(combine)
    con3.execute(combine)
con3.commit()
con3.execute("detach database dba")
票数 25
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/9349659

复制
相关文章

相似问题

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