新聞中心
在Android應(yīng)用程序開發(fā)中,經(jīng)常會(huì)遇到需要進(jìn)行數(shù)據(jù)庫操作的時(shí)候,有關(guān)數(shù)據(jù)庫事務(wù)處理對(duì)Android應(yīng)用程序的穩(wěn)定性和效率提升非常重要。

首先Android數(shù)據(jù)庫操作,特別是進(jìn)行寫操作的時(shí)候非常慢,將所有操作打包成一個(gè)事務(wù)能大大提高處理速度。
其次是保證數(shù)據(jù)的一致性,讓一個(gè)事務(wù)中的所有操作都成功執(zhí)行,或者失敗,或者所有操作回滾。
如果您喜歡使用其他平臺(tái)(如PHP + MySQL),代碼通常在一個(gè)功能強(qiáng)大的服務(wù)器上運(yùn)行,一般不會(huì)被意外中止,但在Android平臺(tái)上,您將會(huì)因?yàn)橐淮斡忠淮蔚囊馔庵兄垢械襟@呀。Android系統(tǒng)會(huì)殺死apps/threads/activities等中斷數(shù)據(jù)庫的使用,電池電量會(huì)耗盡或被移除等。所以,使用數(shù)據(jù)庫事物至關(guān)重要。
實(shí)現(xiàn)android數(shù)據(jù)庫事務(wù)非常簡單,只需要使用SQLiteDatabase類的三個(gè)方法即可。
◆beginTransaction();
◆setTransactionSuccessful();
◆endTransaction();
當(dāng)調(diào)用endTransaction()時(shí),所有從beginTransaction()開始的操作都會(huì)被提交。
一個(gè)簡單的數(shù)據(jù)庫事務(wù)操作如下所示:
- mDatabase.beginTransaction();
- try{
- //在這里執(zhí)行多個(gè)數(shù)據(jù)庫操作
- //執(zhí)行過程中可能會(huì)拋出異常
- mDatabase.setTransactionSuccessful();
- //在setTransactionSuccessful和endTransaction之間不進(jìn)行任何數(shù)據(jù)庫操作
- }catch(Exception e){
- //當(dāng)數(shù)據(jù)庫操作出現(xiàn)錯(cuò)誤時(shí),需要捕獲異常,結(jié)束事務(wù)
- mDatabase.endTransaction();
- throw e;
- }
- //當(dāng)所有操作執(zhí)行完成后結(jié)束一個(gè)事務(wù)
- mDatabase.endTransaction();
- }
以上是關(guān)于Android數(shù)據(jù)庫事務(wù)操作的一個(gè)簡單示例,在我們平時(shí)的Android開發(fā)中,將所有操作打包成一個(gè)事務(wù)為一個(gè)事務(wù)并保證事務(wù)的一致性,可以大幅提高Android數(shù)據(jù)庫操作的效率。
【編輯推薦】
- 多圖詳解 “Android UI”設(shè)計(jì)官方教程
- 在Eclipse下搭建Android開發(fā)環(huán)境教程
- Android開發(fā):系統(tǒng)自動(dòng)實(shí)現(xiàn)開機(jī)啟動(dòng)
- Android的UI設(shè)計(jì)與后臺(tái)線程交互
網(wǎng)站欄目:Android數(shù)據(jù)庫事務(wù)淺析
標(biāo)題來源:http://www.5511xx.com/article/cojhosg.html


咨詢
建站咨詢
