SQLlite数据库中的附加和分离是怎样的
本篇文章为大家展示了SQLlite数据库中的附加和分离是怎样的,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。
在SQLlite数据库中往往一个数据文件就是一个schema,但是在平时的业务或者是一些条件中可能是不同的内容存放在不同的schema中,即不同的数据文件,有的场景下需要数据关联时就可以使用SQLlite的数据附加来建立一个临时的链接。如下,在使用my_test的schema时需要关联查询一个为my_test2的schema就可以使用附加:
[root@localhostdata]#sqlite3my_test.db#在SQLlite数据库中缺省database名为mainSQLiteversion3.6.20Enter".help"forinstructionsEnterSQLstatementsterminatedwitha";"sqlite>.databaseseqnamefile----------------------------------------------------------------------------0main/data/my_test.dbsqlite>ATTACHDATABASE'/data/my_test2.db'As'my_test2';#在当前schema下附加上/data/my_test2.db中的数据,并且起一个别名为my_test2,当然也可以起其他的名字sqlite>.databasesseqnamefile----------------------------------------------------------------------------0main/data/my_test.db2my_test2/data/my_test2.dbsqlite>CREATETABLEmy_test2.test_attach(...>aint(10),...>bint(10)...>);sqlite>SELECT*FROMmy_test2.sqlite_masterWHEREtype='table'ANDtbl_name='test_attach';#直接在当前schema下使用/data/my_test2.db中的数据,并且查看table|test_attach|test_attach|4|CREATETABLEtest_attach(aint(10),bint(10))sqlite>.exit[root@localhostdata]#sqlite3/data/my_test2.db#切换成my_test2.db的schema查看验证下SQLiteversion3.6.20Enter".help"forinstructionsEnterSQLstatementsterminatedwitha";"sqlite>SELECTsqlFROMsqlite_masterWHEREtype='table'ANDtbl_name='test_attach';CREATETABLEtest_attach(aint(10),bint(10))
如此就是在SQLlite数据库中的附加数据库,它其实是一个链接,用于在不同的数据schma数据文件下使用其他的schma数据文件,在这里需要注意的是目前在SQLlite数据库中附加是临时的,在当前session中创建一个链接,如果在退出这个session后附加就自动分离:
[root@localhostdata]#sqlite3/data/my_test.dbSQLiteversion3.6.20Enter".help"forinstructionsEnterSQLstatementsterminatedwitha";"sqlite>.databaseseqnamefile----------------------------------------------------------------------------0main/data/my_test.db当然有如果有附件数据库那一定有分离,分离就比较简单:sqlite>.databasesseqnamefile----------------------------------------------------------------------------0main/data/my_test.db2my_test2/data/my_test2.dbsqlite>DETACHDATABASE"my_test2";sqlite>.databasesseqnamefile----------------------------------------------------------------------------0main/data/my_test.db
这样就成功的主动分离附加在当前schma下的其他数据文件,在这里要特别注意的是如果分离的数据库是在内存或临时空间内,分离后会销毁其分离的数据。
上述内容就是SQLlite数据库中的附加和分离是怎样的,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注亿速云行业资讯频道。
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。