springboot環(huán)境下配置使用sqlite數(shù)據(jù)庫(kù)方式
springboot環(huán)境配置使用sqlite數(shù)據(jù)庫(kù)
在springboot環(huán)境下,使用mybatis配置sqlite數(shù)據(jù)庫(kù)。
pom文件導(dǎo)入mybatis和sqlite依賴
<dependency> <groupId>org.xerial</groupId> <artifactId>sqlite-jdbc</artifactId> <version>3.21.0.1</version> </dependency> <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>1.3.2</version> </dependency>
application.properties配置
spring.datasource.driver-class-name=org.sqlite.JDBC spring.datasource.url=jdbc:sqlite::resource:static/sqllite/web_manage.db spring.datasource.username= spring.datasource.password= mybatis.mapper-locations=classpath:static/mapper/*.xml
具體的url等路徑根據(jù)實(shí)際情況填寫,若是引用項(xiàng)目?jī)?nèi)的db文件,必須以jdbc:sqlite::resource: 開頭,后面填寫存放路徑,一般放在static下的文件內(nèi)。
使用
接下來(lái)就像mybatis配置mysql數(shù)據(jù)庫(kù)完成后一樣,進(jìn)行數(shù)據(jù)的操作即可,sql語(yǔ)句大同小異。
Springboot集成sqlite3遇到的問(wèn)題
使用背景
需要做C/S系統(tǒng),數(shù)據(jù)庫(kù)選擇文檔型的sqlite3
在使用過(guò)程中遇到了一些問(wèn)題
1.sqlite3僅支持?jǐn)?shù)據(jù)庫(kù)單連接
在最開始的時(shí)候由于直接粘貼復(fù)制,導(dǎo)致在每次停止服務(wù)后數(shù)據(jù)庫(kù)都會(huì)被鎖,報(bào)“[SQLITE_BUSY] The database file is locked (database is locked)”異常,后經(jīng)排查,是配置了兩個(gè)數(shù)據(jù)源,導(dǎo)致sqlite3數(shù)據(jù)庫(kù)死鎖。
sqlite3其本質(zhì)是文檔型數(shù)據(jù)庫(kù),在啟動(dòng)項(xiàng)目之后,無(wú)法再用數(shù)據(jù)庫(kù)連接工具連接到數(shù)據(jù)庫(kù)。
在對(duì)數(shù)據(jù)庫(kù)操作時(shí)亦如此,它不支持并行操作,所以在使用多線程操作時(shí)可能會(huì)報(bào)“[SQLITE_BUSY] The database file is locked (database is locked)”異常。
2.在刪除庫(kù)中的數(shù)據(jù)之后,數(shù)據(jù)庫(kù)占用空間未減小
由于我是將數(shù)據(jù)庫(kù)嵌入C/S系統(tǒng),同時(shí)需要對(duì)庫(kù)的數(shù)據(jù)進(jìn)行清理,所以需要在刪除之后清除所占內(nèi)存
原因:從Sqlite刪除數(shù)據(jù)后,未使用的磁盤空間會(huì)被添加到一個(gè)內(nèi)在的”空閑列表”中用于存儲(chǔ)你下次插入的數(shù)據(jù)。磁盤空間并沒有丟失。但是也不向操作系統(tǒng)返回磁盤空間。
解決方案:
方案1.刪除后手動(dòng)執(zhí)行VACUUM命令
由于我是通過(guò)springboot集成的,所以在清空數(shù)據(jù)庫(kù)之后,新加一條清空數(shù)據(jù)庫(kù)的指令
<update id="vacuum"> VACUUM </update>
方案2.在數(shù)據(jù)庫(kù)文件建成中,將auto_vacuum設(shè)置成“1”。
注意:只有在數(shù)據(jù)庫(kù)中未建任何表時(shí)才能改變auto-vacuum標(biāo)記。試圖在已有表的情況下修改不會(huì)導(dǎo)致報(bào)錯(cuò)。
當(dāng)開啟auto-vacuum,當(dāng)提交一個(gè)從數(shù)據(jù)庫(kù)中刪除除數(shù)據(jù)的事物時(shí),數(shù)據(jù)庫(kù)文件自動(dòng)收縮。
數(shù)據(jù)庫(kù)會(huì)在內(nèi)部存儲(chǔ)一些信息以便支持這一功能,這使得數(shù)據(jù)庫(kù)文件比不開啟該選項(xiàng)時(shí)稍微大一些。
推薦使用方案1
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
一篇文章帶你了解JAVA面對(duì)對(duì)象應(yīng)用
Java是一門面向?qū)ο蟮恼Z(yǔ)言。對(duì)象是Java程序中的基本實(shí)體。除了對(duì)象之外Java程序同樣處理基本數(shù)據(jù)。下面這篇文章主要給大家總結(jié)了關(guān)于Java中面向?qū)ο蟮闹R(shí)點(diǎn),需要的朋友可以參考借鑒,下面來(lái)一起看看吧2021-08-08java使用mybatis調(diào)用存儲(chǔ)過(guò)程返回一個(gè)游標(biāo)結(jié)果集方式
這篇文章主要介紹了java使用mybatis調(diào)用存儲(chǔ)過(guò)程返回一個(gè)游標(biāo)結(jié)果集方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-01-01springboot實(shí)現(xiàn)圖片上傳與下載功能
這篇文章主要為大家詳細(xì)介紹了后端spring項(xiàng)目經(jīng)常要做的功能,實(shí)現(xiàn)圖片上傳和下載,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-12-12SpringBoot?整合mapstruct的實(shí)現(xiàn)步驟
這篇文章主要介紹了SpringBoot整合mapstruct,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-11-11Java實(shí)現(xiàn)實(shí)時(shí)監(jiān)控目錄下文件變化的方法
今天小編就為大家分享一篇關(guān)于Java實(shí)現(xiàn)實(shí)時(shí)監(jiān)控目錄下文件變化的方法,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2019-03-03