sqlite 修改表名,合并数据库(文件)

修改表名:
ALTER TABLE orig_table_name RENAME TO tmp_table_name;

将某个数据库的一个表的数据插入到另一个数据库的某个表里:
1、先连接数据库A
2、再attach数据库B作为第二数据库:   ATTACH "c:\database_b\places.sqlite" AS SecondaryDB;   (若还要attach其它数据库,则 ATTACH "c:\database_b\third.sqlite" AS ThirdDB;
3、(若要将B中的某个表的数据追加到A中的某个表中,则: INSERT OR IGNORE INTO MyTable SELECT * FROM SecondaryDB.MyTable;  但条件是这2个表的id主键没有冲突,若有冲突,则修改B的主键)
4、然后:  COMMIT;
5、最后:  DETACH DATABASE SecondaryDB;


将某个数据库的整个表整体的复制到另一个数据库里:
1、先连接数据库A
2、再attach数据库B作为第二数据库:   ATTACH "c:\database_b\places.sqlite" AS SecondaryDB;   (若还要attach其它数据库,则 ATTACH "c:\database_b\third.sqlite" AS ThirdDB;
3、  CREATE TABLE newTableInDB1 AS SELECT * FROM SecondaryDB.oldTableInMyOtherDB;
4、 commit;
5、最后:  DETACH DATABASE SecondaryDB;
附: 
1、查看表的schema格式:  .schema tablename      或者 PRAGMA SecondaryDB.table_info(table_name);
2、对于attached数据库,若要查看它的表,则:  SELECT name FROM SecondaryDB.sqlite_master WHERE type='table';

转载于:https://www.cnblogs.com/welhzh/p/4232107.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要使用SQLite存储格式保存数据库文件,你可以按照以下步骤进行操作: 1. 在你的C/C++项目中引入SQLite库。你可以从SQLite官方网站(https://www.sqlite.org/download.html)下载SQLite的预编译二进制文件,并将其添加到你的项目中。 2. 使用SQLite API打开数据库连接,并创建格以存储数据。 ```cpp #include <sqlite3.h> sqlite3* db; int rc = sqlite3_open("path/to/database.db", &db); if (rc != SQLITE_OK) { printf("Error opening database: %s\n", sqlite3_errmsg(db)); return; } // 创建格 const char* createTableQuery = "CREATE TABLE IF NOT EXISTS your_table (field1 TEXT, field2 INTEGER, ...)"; rc = sqlite3_exec(db, createTableQuery, 0, 0, 0); if (rc != SQLITE_OK) { printf("Error creating table: %s\n", sqlite3_errmsg(db)); sqlite3_close(db); return; } ``` 3. 执行插入语句,将数据保存到数据库中。 ```cpp // 执行插入语句 const char* insertQuery = "INSERT INTO your_table (field1, field2, ...) VALUES (?, ?, ...)"; sqlite3_stmt* stmt; rc = sqlite3_prepare_v2(db, insertQuery, -1, &stmt, 0); if (rc != SQLITE_OK) { printf("Error preparing statement: %s\n", sqlite3_errmsg(db)); sqlite3_close(db); return; } while (query.next()) { // 绑定参数 sqlite3_bind_text(stmt, 1, query.value(0).toString().toUtf8().constData(), -1, SQLITE_STATIC); sqlite3_bind_int(stmt, 2, query.value(1).toInt()); // 绑定其他参数... // 执行插入操作 rc = sqlite3_step(stmt); if (rc != SQLITE_DONE) { printf("Error inserting record: %s\n", sqlite3_errmsg(db)); sqlite3_finalize(stmt); sqlite3_close(db); return; } // 重置语句 sqlite3_reset(stmt); } sqlite3_finalize(stmt); ``` 4. 关闭数据库连接。 ```cpp sqlite3_close(db); ``` 请注意,以上代码只是示例,你需要根据实际情况进行适当的修改和调整。另外,SQLite提供了更多的API函数用于执行查询、更新和删除操作,你可以根据自己的需求进行使用。同时,你也可以使用SQLite提供的命令行工具或其他SQLite客户端工具来管理和查看保存在SQLite数据库中的数据。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值