- SQLite 教程
- SQLite - 首页
- SQLite - 概述
- SQLite - 安装
- SQLite - 命令
- SQLite - 语法
- SQLite - 数据类型
- SQLite - 创建数据库
- SQLite - 附加数据库
- SQLite - 分离数据库
- SQLite - 创建表
- SQLite - 删除表
- SQLite - INSERT 查询
- SQLite - SELECT 查询
- SQLite - 运算符
- SQLite - 表达式
- SQLite - WHERE 子句
- SQLite - AND & OR 子句
- SQLite - UPDATE 查询
- SQLite - DELETE 查询
- SQLite - LIKE 子句
- SQLite - GLOB 子句
- SQLite - LIMIT 子句
- SQLite - ORDER BY 子句
- SQLite - GROUP BY 子句
- SQLite - HAVING 子句
- SQLite - DISTINCT 关键字
- 高级 SQLite
- SQLite - PRAGMA
- SQLite - 约束
- SQLite - JOIN
- SQLite - UNION 子句
- SQLite - NULL 值
- SQLite - 别名语法
- SQLite - 触发器
- SQLite - 索引
- SQLite - INDEXED BY 子句
- SQLite - ALTER 命令
- SQLite - TRUNCATE 命令
- SQLite - 视图
- SQLite - 事务
- SQLite - 子查询
- SQLite - AUTOINCREMENT
- SQLite - 注入
- SQLite - EXPLAIN
- SQLite - VACUUM
- SQLite - 日期和时间
- SQLite - 常用函数
- SQLite 有用资源
- SQLite - 快速指南
- SQLite - 有用资源
- SQLite - 讨论
SQLite - 附加数据库
考虑这样一种情况:您有多个数据库可用,并且您希望一次使用其中的一个。SQLite 的 **ATTACH DATABASE** 语句用于选择特定的数据库,在此命令之后,所有 SQLite 语句都将在附加的数据库下执行。
语法
以下是 SQLite ATTACH DATABASE 语句的基本语法。
ATTACH DATABASE 'DatabaseName' As 'Alias-Name';
如果数据库尚未创建,上述命令还会创建一个数据库;否则,它只会将数据库文件名与逻辑数据库“别名”关联。
示例
如果您要附加现有的数据库 **testDB.db**,则 ATTACH DATABASE 语句如下所示:
sqlite> ATTACH DATABASE 'testDB.db' as 'TEST';
使用 SQLite **.database** 命令显示附加的数据库。
sqlite> .database seq name file --- --------------- ---------------------- 0 main /home/sqlite/testDB.db 2 test /home/sqlite/testDB.db
数据库名称 **main** 和 **temp** 分别保留用于主数据库和用于保存临时表和其他临时数据对象的数据库。这两个数据库名称在每个数据库连接中都存在,不应用于附加,否则您将收到以下警告消息。
sqlite> ATTACH DATABASE 'testDB.db' as 'TEMP'; Error: database TEMP is already in use sqlite> ATTACH DATABASE 'testDB.db' as 'main'; Error: database TEMP is already in use
广告