您现在的位置是:亿华云 > IT科技类资讯
SQLlite数据库中的附加和分离
亿华云2025-10-04 01:24:59【IT科技类资讯】5人已围观
简介在SQLlite数据库中往往一个数据文件就是一个schema,但是在平时的业务或者是一些条件中可能是不同的内容存放在不同的schema中,即不同的数据文件,有的场景下需要数据关联时就可以使用SQLli
在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下的其他数据文件,在这里要特别注意的是如果分离的数据库是在内存或临时空间内,分离后会销毁其分离的数据。
很赞哦!(5)
相关文章
- 4、参加域名拍卖会
- 用CSS实现一个抽奖转盘(附详细代码+思路)
- 不会编程也能做酷炫视频风格迁移?这个工具冲上Reddit热榜
- 响应式网页中的高度设计,你认真的吗?
- 域后缀首选.com,.net,然后是.cn。后缀选择不当,导致流量损失。域名是企业与互联网网址之间的链接,关键是企业在网络上存在的标志。因此,选择好域名是开展网上工作的首要重要条件。
- 2020年12月编程语言排行榜:Python年度编程语言预订?Java重回第二
- 开源平台 GitLab又开始搞事情:大规模封杀开发者账户
- 值得推荐的13个 Jenkins 替代方案
- 旧域名的外链是否会对新建站点产生影响?
- 2020 Google 开发者大会主题演讲:代码不止 赋能创新