久久精品国产亚洲高清|精品日韩中文乱码在线|亚洲va中文字幕无码久|伊人久久综合狼伊人久久|亚洲不卡av不卡一区二区|精品久久久久久久蜜臀AV|国产精品19久久久久久不卡|国产男女猛烈视频在线观看麻豆

    1. <style id="76ofp"></style>

      <style id="76ofp"></style>
      <rt id="76ofp"></rt>
      <form id="76ofp"><optgroup id="76ofp"></optgroup></form>
      1. 千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機構(gòu)

        手機站
        千鋒教育

        千鋒學(xué)習(xí)站 | 隨時隨地免費學(xué)

        千鋒教育

        掃一掃進入千鋒手機站

        領(lǐng)取全套視頻
        千鋒教育

        關(guān)注千鋒學(xué)習(xí)站小程序
        隨時隨地免費學(xué)習(xí)課程

        當前位置:首頁  >  技術(shù)干貨  > 為什么sqlite會返回database locked而別的數(shù)據(jù)庫不會?

        為什么sqlite會返回database locked而別的數(shù)據(jù)庫不會?

        來源:千鋒教育
        發(fā)布人:xqq
        時間: 2023-10-13 15:53:23 1697183603

        一、為什么sqlite會返回database locked而別的數(shù)據(jù)庫不會

        sqlite可以支持多個進程同時讀取,但不支持同時寫入,主要原因是因為它默認采用了串行化的事務(wù)隔離,他在寫數(shù)據(jù)到文件的時候加了一把文件粒度的排他鎖,這個時候是不能并發(fā)讀取的和寫入的,這時如果有請求就會進入等待。

        等待超時后會拋出database is locked錯誤。這個和嵌入式?jīng)]什么關(guān)系,嵌入式數(shù)據(jù)庫同樣可以通過文件鎖、共享內(nèi)存等方式實現(xiàn)多進程訪問,通過快照隔離實現(xiàn)并發(fā)讀寫。

        MySQL里面的myisam引擎其實也是不支持并發(fā)讀寫的,現(xiàn)在用的比較少,innodb存儲引擎則是通過MVCC支持并發(fā)讀寫的。

        sqlite遇到database is locked問題的完美解決
        1、使用進程或線程間的同步機制以避免同時操作;如用信號量,互斥鎖等(pthread_mutex_lock,
        pthread_mutex_unlock),如果你的項目工程較大要求較高的話建議用此方法自行封裝函數(shù)處理同步
        2、使用sqlite提供的兩個busy handler函數(shù),但對于一個連接來說,只能有一個busy handle,兩個函數(shù)會相互影響,設(shè)
        置一個的同時會清除另一個,應(yīng)根據(jù)需要來選擇。
        int sqlite3_busy_handler(sqlite3 *, int (*)(void *, int), void *)
        不注冊此函數(shù)時默認回調(diào)函數(shù)為NULL,清除busy handle,申請不到鎖直接返回;
        函數(shù)可以定義一個回調(diào)函數(shù),當出現(xiàn)數(shù)據(jù)庫忙時sqlite會調(diào)用該函數(shù)進行延時并返回非0會重試本次操作,回調(diào)函數(shù)的第二個
        參數(shù)會被傳遞為此次因BUSY忙事件而調(diào)用該函數(shù)的次數(shù),因此你完全可以自行控制多少次后(也就是延時多少后)才真正返回
        BUSY;
        回調(diào)函數(shù)返回非0,數(shù)據(jù)庫會重試當前操作,返回0則當前操作返回SQLITE_BUSY;
        int sqlite3_busy_timeout(sqlite3*, int ms);
        不注冊此函數(shù)時默認超時等待為0,當ms<=0時,清除busy handle,申請不到鎖直接返回;
        定義一個毫秒數(shù),當未到達該毫秒數(shù)時,sqlite會sleep并重試當前操作,
        如果超過ms毫秒,仍然申請不到需要的鎖,當前操作返回SQLITE_BUSY;
        很多人用這個函數(shù)沒有成功,其實只要你仔細查看sqlite的源碼就會發(fā)現(xiàn),
        這個函數(shù)實際上注冊了一個默認的sqlite3_busy_handler(sqliteDefaultBusyCallback),而這個回調(diào)函數(shù)在你的編譯
        環(huán)境下可能使得第二個ms參數(shù)必需要大于1000且是他的整數(shù)倍才有意義,由于此默認callback函數(shù)延時較大,建議自己寫回
        調(diào)函數(shù)然后用slite3_busy_handler注冊,這樣就可以自己用自己的延時函數(shù)或方法進行處理了。

        延伸閱讀:

        二、SQL是什么

        Structured Query Language

        ‘SQL’是結(jié)構(gòu)化查詢語言,是一種用來操作?RDBMS?的數(shù)據(jù)庫語言,當前關(guān)系型數(shù)據(jù)庫都支持使用SQL語言進行操作,也就是說可以通過?SQL?操作 oracle,sql server,mysql,sqlite 等等所有的關(guān)系型的數(shù)據(jù)庫

        SQL語句主要分為:
        DQL:數(shù)據(jù)查詢語言,用于對數(shù)據(jù)進行查詢,如select**
        DML:數(shù)據(jù)操作語言,對數(shù)據(jù)進行增加、修改、刪除,如insert、udpate、delete**
        TPL:事務(wù)處理語言,對事務(wù)進行處理,包括begin transaction、commit、rollback
        DCL:數(shù)據(jù)控制語言,進行授權(quán)與權(quán)限回收,如grant、revoke
        DDL:數(shù)據(jù)定義語言,進行數(shù)據(jù)庫、表的管理等,如create、drop
        CCL:指針控制語言,通過控制指針完成表的操作,如declare cursor對于web程序員來講,重點是數(shù)據(jù)的crud(增刪改查),必須熟練編寫DQL、DML,能夠編寫DDL完成數(shù)據(jù)庫、表的操作,其它語言如TPL、DCL、CCL了解即可SQL 是一門特殊的語言,專門用來操作關(guān)系數(shù)據(jù)庫不區(qū)分大小寫
        聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
        10年以上業(yè)內(nèi)強師集結(jié),手把手帶你蛻變精英
        請您保持通訊暢通,專屬學(xué)習(xí)老師24小時內(nèi)將與您1V1溝通
        免費領(lǐng)取
        今日已有369人領(lǐng)取成功
        劉同學(xué) 138****2860 剛剛成功領(lǐng)取
        王同學(xué) 131****2015 剛剛成功領(lǐng)取
        張同學(xué) 133****4652 剛剛成功領(lǐng)取
        李同學(xué) 135****8607 剛剛成功領(lǐng)取
        楊同學(xué) 132****5667 剛剛成功領(lǐng)取
        岳同學(xué) 134****6652 剛剛成功領(lǐng)取
        梁同學(xué) 157****2950 剛剛成功領(lǐng)取
        劉同學(xué) 189****1015 剛剛成功領(lǐng)取
        張同學(xué) 155****4678 剛剛成功領(lǐng)取
        鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
        董同學(xué) 138****2867 剛剛成功領(lǐng)取
        周同學(xué) 136****3602 剛剛成功領(lǐng)取
        相關(guān)推薦HOT
        mysql.sock文件是怎么起作用的?

        一、mysql.sock文件的工作原理在MySQL中,mysql.sock文件是用于實現(xiàn)本地套接字(socket)連接的一種機制。它在Unix或類Unix系統(tǒng)上使用,允許客...詳情>>

        2023-10-13 17:39:11
        oracle為什么要繼續(xù)開發(fā)mysql?

        一、oracle為什么要繼續(xù)開發(fā)mysql應(yīng)該是之前收購的時候有協(xié)議吧,而且,本身面向的客戶也不太一樣。oracle也有不付費的用戶,mysql有社區(qū)版,但...詳情>>

        2023-10-13 17:27:29
        低代碼平臺的開發(fā),數(shù)據(jù)庫是怎么選擇的?

        一、低代碼平臺的開發(fā),數(shù)據(jù)庫是怎么選擇的如果你選擇的低代碼開發(fā)平臺支持多種數(shù)據(jù)庫,那就選你最熟悉的吧。除了oracle這種賊貴的,和postgres...詳情>>

        2023-10-13 17:25:32
        MySQL本地事務(wù)和MySQL XA事務(wù)的區(qū)別是什么?

        一、MySQL本地事務(wù)和MySQL XA事務(wù)的區(qū)別MySQL本地事務(wù)是指在單個數(shù)據(jù)庫連接上執(zhí)行的事務(wù)操作,通常用于單個數(shù)據(jù)庫實例上的事務(wù)處理。它遵循數(shù)據(jù)...詳情>>

        2023-10-13 17:16:58
        foxmail 7.2使用的是什么方式存儲的郵件?

        一、foxmail 7.2使用的是什么方式存儲的郵件1、foxmail郵件存儲位置在大家的安裝目錄下,我們可以直接右擊foxmail圖標然后我們點擊“打開文件位...詳情>>

        2023-10-13 17:08:36
        快速通道
        乐东| 宾川县| 鲜城| 泰和县| 金堂县| 西昌市| 南陵县| 北碚区| 合江县| 神木县| 泾源县| 桐庐县| 南郑县| 达拉特旗| 酉阳| 黑龙江省| 贵溪市| 海阳市| 乌拉特后旗| 安溪县| 淅川县| 犍为县| 邳州市| 文山县| 登封市| 屏东市| 精河县| 辽源市| 札达县| 永新县| 开远市| 天台县| 绥江县| 雅江县| 洛阳市| 忻州市| 托里县| 岗巴县| 金沙县| 忻州市| 仁化县|