亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > 綜合 > 正文

SQLite數據庫用來處理鎖定情況的兩個函數

2024-07-21 02:43:42
字體:
來源:轉載
供稿:網友
SQLite數據庫在使用的過程中經常發生的數據庫異常便是數據庫被鎖定了(SQLITE_BUSY或者SQLITE_LOCKED)。SQLite對于并發的處理機制是允許同一個進程的多個線程同時讀取一個數據庫,但是任何時刻只允許一個線程/進程寫入數據庫。所以必須要對數據庫的讀寫來進行控制。

SQLite數據庫本身用來處理鎖定情況的兩個函數:

int sqlite3_busy_handler(sqlite3*, int(*)(void*,int), void*);

int sqlite3_busy_timeout(sqlite3*, int ms);

使用這兩個函數可以設定當發生數據庫鎖定的時候,調用什么函數來處理,以及設定鎖定時的等待時間。

當然通常情況下我們還可以用另外一種方法來解決這類問題,那便是設置互斥量。一般情況下我們可以使用互斥量,臨界區等來實現。在這里我使用了互斥量,主要是因為我需要在多個不同的進程中并發的訪問同一個數據庫。用于鎖定和解鎖的函數如下:

void Lock()

{

if((hCounter = OpenMutex(MUTEX_ALL_access,FALSE,"kangxiaofang")) == NULL)

{

//如果沒有其他進程創建這個互斥量,則重新創建

hCounter = CreateMutex(NULL,FALSE,"kangxiaofang");

WaitForSingleObject(hCounter,INFINITE);

}

else

{

WaitForSingleObject(hCounter,INFINITE);

}

}

void UnLock()

{

//釋放使用權

ReleaseMutex(hCounter);

//關閉句柄

CloseHandle(hCounter);

}

當然我們也可以把等待時間設定為60秒,以免出現死等的現象。具體使用時可以按如下調用:

//鎖定數據庫

Lock();

rc = sqlite3_exec(db, "BEGIN;", 0, 0, &zErrMsg);

rc = sqlite3_exec(db, exec, 0, 0, &zErrMsg);

rc = sqlite3_exec(db, "COMMIT;", 0, 0, &zErrMsg);

//數據庫解鎖

UnLock();

總結:

經過測試后,你會發現這種方法所需的消耗要小于循環打開數據庫的操作。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
在线日韩日本国产亚洲| 国产专区精品视频| 亚洲二区在线播放视频| 亚洲国产成人在线视频| 91久久国产婷婷一区二区| 欧美日韩亚洲精品一区二区三区| 亚洲偷熟乱区亚洲香蕉av| 欧美成aaa人片在线观看蜜臀| 麻豆国产va免费精品高清在线| 亚洲视频在线观看免费| 久久精品国产成人精品| 最近2019中文字幕大全第二页| 久久韩剧网电视剧| 欧美电影免费在线观看| 2021久久精品国产99国产精品| 国产成人在线一区| 国产精品扒开腿做爽爽爽的视频| 97超碰国产精品女人人人爽| 久久国产精品久久国产精品| 91精品久久久久久久久不口人| 国产丝袜一区视频在线观看| 国产欧美一区二区三区视频| 91精品国产色综合久久不卡98| 日韩亚洲成人av在线| 亚洲国产小视频在线观看| 在线观看日韩专区| 性欧美亚洲xxxx乳在线观看| 欧美日韩裸体免费视频| 欧美孕妇性xx| 国产精品视频在线播放| 欧美激情久久久久久| 最新91在线视频| 91在线观看免费观看| 欧美大片网站在线观看| 美女av一区二区三区| 国产精品久久久久久久一区探花| 亚洲日本欧美日韩高观看| 亚洲男人天堂九九视频| 国产精品久久久久高潮| 国产日韩欧美综合| 亚洲欧美激情视频| 久久久久久久久久久人体| 亚洲成人激情在线观看| 国产精品91一区| 亚洲国产欧美一区| 亚洲一区免费网站| 黑人狂躁日本妞一区二区三区| 国产精品亚洲片夜色在线| 红桃av永久久久| 国产精品男人的天堂| 91视频国产精品| 亚洲一区免费网站| 欧美黑人一区二区三区| 国产日韩欧美综合| 亚洲性av在线| 欧美午夜性色大片在线观看| 日韩中文字幕在线播放| 欧美综合国产精品久久丁香| 欧美中文字幕在线视频| 国产成人精彩在线视频九色| 俺去亚洲欧洲欧美日韩| 91性高湖久久久久久久久_久久99| 91日本视频在线| 国产亚洲精品久久久优势| 2020久久国产精品| 91精品视频免费观看| 欧美中文字幕精品| 97精品久久久中文字幕免费| 亚洲国产精品国自产拍av秋霞| 欧美高清视频在线观看| 久久人人爽人人| 一本一本久久a久久精品牛牛影视| 成人免费xxxxx在线观看| 久久综合国产精品台湾中文娱乐网| 日韩av综合网站| 欧美中文字幕视频在线观看| 欧美精品videos性欧美| 欧美大秀在线观看| 国产精品网站入口| 久久九九国产精品怡红院| 亚洲国产精品热久久| 欧美丰满老妇厨房牲生活| 米奇精品一区二区三区在线观看| 欧美激情欧美激情在线五月| 中国人与牲禽动交精品| 欧美激情视频播放| 国产精品久久久久久亚洲影视| 亚洲人成欧美中文字幕| 亚洲图片制服诱惑| 国产成人啪精品视频免费网| 日韩a**站在线观看| 亚洲免费电影一区| 亚洲欧美国产一区二区三区| 欧美精品在线免费| 日韩欧美国产成人| 亚洲国产精品久久久久久| 亚洲国产古装精品网站| 成人精品在线视频| 日本一区二区三区在线播放| 色伦专区97中文字幕| 中文亚洲视频在线| 亚洲午夜女主播在线直播| 日韩中文字幕视频在线| 国产精品久久久久999| 伊人伊成久久人综合网小说| 日韩av网站在线| 欧美国产极速在线| 在线观看日韩视频| 久久人91精品久久久久久不卡| 中文字幕欧美日韩va免费视频| 精品动漫一区二区三区| 色噜噜亚洲精品中文字幕| 55夜色66夜色国产精品视频| 欧日韩在线观看| 亚洲free性xxxx护士hd| 日韩精品免费视频| 午夜欧美大片免费观看| 久久国产视频网站| 久久久久久亚洲精品不卡| 亚洲男人的天堂网站| 久久男人av资源网站| 欧美激情奇米色| 一本色道久久88精品综合| 成人午夜激情免费视频| 国产精品久久久久久久久久久久久久| 久久成人精品电影| 久久久久久免费精品| 国产精品高清在线观看| 亚洲精品在线看| 日本欧美一级片| 色婷婷久久一区二区| 精品一区二区三区三区| www国产亚洲精品久久网站| 国产成人精品在线| 欧美日韩激情视频8区| 国产欧美精品在线播放| 国产精品极品美女粉嫩高清在线| 亚洲在线观看视频| 中文字幕日韩av电影| 日韩成人黄色av| 欧美最近摘花xxxx摘花| 91夜夜未满十八勿入爽爽影院| 国产成人精品久久| 国产精品久久久久久久天堂| 久久综合色影院| 亚洲欧美日韩国产中文| 欧美专区福利在线| 久久久国产一区二区三区| 91精品国产91| 国产免费一区二区三区在线能观看| 深夜福利日韩在线看| 播播国产欧美激情| 久久久精品免费视频| 欧美精品videos性欧美| 亚洲在线视频福利| 午夜精品一区二区三区av| 久久免费视频这里只有精品| 成人性生交大片免费看小说| 亚洲网址你懂得| 欧美电影免费观看高清完整| 91精品国产乱码久久久久久久久| 日韩欧美成人免费视频| 91色视频在线观看| 国产日韩欧美在线播放|