SQLite教程(五):数据库和事务
2018-10-12 14:08
633 查看
一、Attach数据库:
ATTACH DATABASE语句添加另外一个数据库文件到当前的连接中,如果文件名为":memory:",我们可以将其视为内存数据库,内存数据库无法持久化到磁盘文件上。如果操作Attached数据库中的表,则需要在表名前加数据库名,如dbname.table_name。最后需要说明的是,如果一个事务包含多个Attached数据库操作,那么该事务仍然是原子的。见如下示例:
sqlite> CREATE TABLE testtable (first_col integer);
sqlite> INSERT INTO testtable VALUES(1);
sqlite> .backup 'D:/mydb.db' --将当前连接中的主数据库备份到指定文件。
sqlite> .exit
--重新登录sqlite命令行工具:
sqlite> CREATE TABLE testtable (first_col integer);
sqlite> INSERT INTO testtable VALUES(2);
sqlite> INSERT INTO testtable VALUES(1);
sqlite> ATTACH DATABASE 'D:/mydb.db' AS mydb;
sqlite> .header on --查询结果将字段名作为标题输出。
sqlite> .mode column --将每列都分开显示。
sqlite> SELECT t1.first_col FROM testtable t1, mydb.testtable t2 WHERE t.first_col = t2.first_col;
first_col
----------
1
二、Detach数据库:
卸载将当前连接中的指定数据库,注意main和temp数据库无法被卸载。见如下示例:
--该示例承载上面示例的结果,即mydb数据库已经被Attach到当前的连接中。
sqlite> DETACH DATABASE mydb;
sqlite> SELECT t1.first_col FROM testtable t1, mydb.testtable t2 WHERE t.first_col = t2.first_col;
Error: no such table: mydb.testtable
三、事务:
在SQLite中,如果没有为当前的SQL命令(SELECT除外)显示的指定事务,那么SQLite会自动为该操作添加一个隐式的事务,以保证该操作的原子性和一致性。当然,SQLite也支持显示的事务,其语法与大多数关系型数据库相比基本相同。见如下示例:
sqlite> BEGIN TRANSACTION;
sqlite> INSERT INTO testtable VALUES(1);
sqlite> INSERT INTO testtable VALUES(2);
sqlite> COMMIT TRANSACTION; --显示事务被提交,数据表中的数据也发生了变化。
sqlite> SELECT COUNT(*) FROM testtable;
COUNT(*)
----------
2
sqlite> BEGIN TRANSACTION;
sqlite> INSERT INTO testtable VALUES(1);
sqlite> ROLLBACK TRANSACTION; --显示事务被回滚,数据表中的数据没有发生变化。
sqlite> SELECT COUNT(*) FROM testtable;
COUNT(*)
----------
2
您可能感兴趣的文章:
相关文章推荐
- SQLite教程(五):数据库和事务
- Android SQLite数据库—事务
- 打开、关闭、创建 数据库 -sqlite 基础教程(4)
- Android[高级教程] Android数据库SQLite表内设置外键
- sqlite 数据库的实践,事务和升级数据库
- 启用事务操作,解决批量插入或更新sqlite,mssql等数据库耗时问题
- PHP入门教程之使用Mysqli操作数据库的方法(连接,查询,事务回滚等)
- 打开、关闭、创建 数据库 -sqlite 基础教程(4)
- Android 高手进阶教程(十三)之----Android 数据库SQLiteDatabase的使用!!
- Android 高手进阶教程(十三)之----Android 数据库SQLiteDatabase的使用!!
- Android -- SQLite 数据库创建,增删改查,事务处理
- Linux+Redis实战教程_day02_Redis特性(数据库、服务器命令、消息订阅与发布、事务)
- Android 高手进阶教程(十三)之----Android 数据库SQLiteDatabase的使用!!
- Scott Mitchell 的ASP.NET 2.0数据教程之63:在事务里对数据库修改进行封装
- Android 高手进阶教程(十三)之----Android 数据库SQLiteDatabase的使用!
- Android -- SQLite 数据库创建,增删改查,事务处理
- Android开发SQLite轻量级数据库增删改查教程
- [Sqlite]-->嵌入式数据库事务理解以及实例操作
- 启用事务操作,解决批量插入或更新sqlite,mssql等数据库耗时问题
- Android 高手进阶教程(十二)----Android数据库SQLiteDatabase的使用!!