阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

SQLlite数据库中的附加和分离

106次阅读
没有评论

共计 2523 个字符,预计需要花费 7 分钟才能阅读完成。

在 SQLlite 数据库中往往一个数据文件就是一个 schema,但是在平时的业务或者是一些条件中可能是不同的内容存放在不同的 schema 中,即不同的数据文件,有的场景下需要数据关联时就可以使用 SQLlite 的数据附加来建立一个临时的链接。如下,在使用 my_test 的 schema 时需要关联查询一个为 my_test2 的 schema 就可以使用附加:

[root@localhost data]# sqlite3 my_test.db #在 SQLlite 数据库中缺省 database 名为 main
SQLite version 3.6.20
Enter ".help" for instructions
Enter SQL statements terminated with a ";"
sqlite> .database
seq  name             file                                                     
---  ---------------  ----------------------------------------------------------
0    main             /data/my_test.db
sqlite> ATTACH DATABASE '/data/my_test2.db' As 'my_test2'# 在当前 schema 下附加上 /data/my_test2.db 中的数据,并且起一个别名为 my_test2,当然也可以起其他的名字
sqlite> .databases
seq  name             file                                                     
---  ---------------  ----------------------------------------------------------
0    main             /data/my_test.db                                         
2    my_test2         /data/my_test2.db
sqlite> CREATE TABLE my_test2.test_attach (
   ...>   a int(10),
   ...>   b int(10)
   ...> );
sqlite> SELECT * FROM my_test2.sqlite_master WHERE type 'table' AND tbl_name = 'test_attach'# 直接在当前 schema 下使用 /data/my_test2.db 中的数据,并且查看
table|test_attach|test_attach|4|CREATE TABLE test_attach (
  a int(10),
  b int(10)
)
sqlite> .exit
[root@localhost data]# sqlite3 /data/my_test2.db #切换成 my_test2.db 的 schema 查看验证下
SQLite version 3.6.20
Enter ".help" for instructions
Enter SQL statements terminated with a ";"
sqlite> SELECT sql FROM sqlite_master WHERE type 'table' AND tbl_name = 'test_attach';
CREATE TABLE test_attach (
  a int(10),
  b int(10)
)

如此就是在 SQLlite 数据库中的附加数据库,它其实是一个链接,用于在不同的数据 schma 数据文件下使用其他的 schma 数据文件,在这里需要注意的是目前在 SQLlite 数据库中附加是临时的,在当前 session 中创建一个链接,如果在退出这个 session 后附加就自动分离:

[root@localhost data]# sqlite3 /data/my_test.db 
SQLite version 3.6.20
Enter ".help" for instructions
Enter SQL statements terminated with a ";"
sqlite> .database
seq  name             file                                                     
---  ---------------  ----------------------------------------------------------
0    main             /data/my_test.db

当然有如果有附件数据库那一定有分离,分离就比较简单:

sqlite> .databases
seq  name             file                                                     
---  ---------------  ----------------------------------------------------------
0    main             /data/my_test.db                                         
2    my_test2         /data/my_test2.db
sqlite> DETACH DATABASE "my_test2";
sqlite> .databases                 
seq  name             file                                                     
---  ---------------  ----------------------------------------------------------
0    main             /data/my_test.db

这样就成功的主动分离附加在当前 schma 下的其他数据文件,在这里要特别注意的是如果分离的数据库是在内存或临时空间内,分离后会销毁其分离的数据。

本文永久更新链接地址 :http://www.linuxidc.com/Linux/2018-01/150008.htm

正文完
星哥说事-微信公众号
post-qrcode
 
星锅
版权声明:本站原创文章,由 星锅 2022-01-22发表,共计2523字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中