欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

springboot環(huán)境下配置使用sqlite數(shù)據(jù)庫(kù)方式

 更新時(shí)間:2024年05月22日 10:24:56   作者:一路1向北  
這篇文章主要介紹了springboot環(huán)境下配置使用sqlite數(shù)據(jù)庫(kù)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

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)文章

  • JVM 參數(shù)配置詳細(xì)介紹

    JVM 參數(shù)配置詳細(xì)介紹

    這篇文章主要介紹了JVM 參數(shù)配置詳細(xì)介紹的相關(guān)資料,需要的朋友可以參考下
    2017-02-02
  • Java中的異常和處理機(jī)制實(shí)例詳解

    Java中的異常和處理機(jī)制實(shí)例詳解

    這篇文章主要介紹了Java中的異常和處理機(jī)制,結(jié)合實(shí)例形式詳細(xì)分析了Java異常與處理機(jī)制的相關(guān)概念、原理、用法及操作注意事項(xiàng),需要的朋友可以參考下
    2019-05-05
  • java中成員變量與局部變量區(qū)別分析

    java中成員變量與局部變量區(qū)別分析

    這篇文章主要介紹了java中成員變量與局部變量區(qū)別,較為詳細(xì)的分析了java中成員變量與局部變量的功能、用法與區(qū)別,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-01-01
  • 一篇文章帶你了解JAVA面對(duì)對(duì)象應(yīng)用

    一篇文章帶你了解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-08
  • Java由淺入深講解繼承上

    Java由淺入深講解繼承上

    繼承就是可以直接使用前輩的屬性和方法。自然界如果沒有繼承,那一切都是處于混沌狀態(tài)。多態(tài)是同一個(gè)行為具有多個(gè)不同表現(xiàn)形式或形態(tài)的能力。多態(tài)就是同一個(gè)接口,使用不同的實(shí)例而執(zhí)行不同操作
    2022-04-04
  • java使用mybatis調(diào)用存儲(chǔ)過(guò)程返回一個(gè)游標(biāo)結(jié)果集方式

    java使用mybatis調(diào)用存儲(chǔ)過(guò)程返回一個(gè)游標(biāo)結(jié)果集方式

    這篇文章主要介紹了java使用mybatis調(diào)用存儲(chǔ)過(guò)程返回一個(gè)游標(biāo)結(jié)果集方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • springboot實(shí)現(xiàn)圖片上傳與下載功能

    springboot實(shí)現(xiàn)圖片上傳與下載功能

    這篇文章主要為大家詳細(xì)介紹了后端spring項(xiàng)目經(jīng)常要做的功能,實(shí)現(xiàn)圖片上傳和下載,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2024-12-12
  • 關(guān)于Spring中的三級(jí)緩存解析

    關(guān)于Spring中的三級(jí)緩存解析

    這篇文章主要介紹了關(guān)于Spring中的三級(jí)緩存,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • SpringBoot?整合mapstruct的實(shí)現(xiàn)步驟

    SpringBoot?整合mapstruct的實(shí)現(xiàn)步驟

    這篇文章主要介紹了SpringBoot整合mapstruct,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • Java實(shí)現(xiàn)實(shí)時(shí)監(jiān)控目錄下文件變化的方法

    Java實(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

最新評(píng)論