![快速上手Android數(shù)據(jù)庫操作_第1頁](http://file4.renrendoc.com/view/1b801af9960e673e0526cb8b855c8830/1b801af9960e673e0526cb8b855c88301.gif)
![快速上手Android數(shù)據(jù)庫操作_第2頁](http://file4.renrendoc.com/view/1b801af9960e673e0526cb8b855c8830/1b801af9960e673e0526cb8b855c88302.gif)
![快速上手Android數(shù)據(jù)庫操作_第3頁](http://file4.renrendoc.com/view/1b801af9960e673e0526cb8b855c8830/1b801af9960e673e0526cb8b855c88303.gif)
![快速上手Android數(shù)據(jù)庫操作_第4頁](http://file4.renrendoc.com/view/1b801af9960e673e0526cb8b855c8830/1b801af9960e673e0526cb8b855c88304.gif)
![快速上手Android數(shù)據(jù)庫操作_第5頁](http://file4.renrendoc.com/view/1b801af9960e673e0526cb8b855c8830/1b801af9960e673e0526cb8b855c88305.gif)
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
快速上手Android數(shù)據(jù)庫操作Android采用關(guān)系型數(shù)據(jù)庫SQLite3,它是一個支持SQL輕量級的嵌入式數(shù)據(jù)庫,在嵌入式操作系統(tǒng)上有很廣泛的應(yīng)用,WM采用的也是SQLite3關(guān)于過于、原理方面的東西在這篇文章里不會提到,但是如果你想能夠快速的學(xué)會操作SQLite3,那這就是你要找的文章!首先,我們看一下api,所有數(shù)據(jù)庫相關(guān)的接口、類都在android.database和android.database,sqlite兩個包下,雖然只有兩個包,但是如果你英文不好或是太懶的話也要迷茫一段時間,其實,我們真正用的到的沒有兒個!SQLiteOpenHelper(android,database,sqlite.SQLiteOpenHelper)這是一個抽象類,關(guān)于抽象類我們都知道,如果要使用它,一定是繼承它!這個類的方法很少,有一個構(gòu)造方法SQLiteOpenHelper(android,content.Contextcontext, java.lang.Stringname,android,database,sqlite.SQLiteDatabase.CursorFactoryfactory,intversion);參數(shù)不做過多的解釋,CursorFactory一般直接傳null就可以publicvoidonCreate(SQLiteDatabasedb)此方法在創(chuàng)建數(shù)據(jù)庫是被調(diào)用,所以,應(yīng)該把創(chuàng)建表的操作放到這個方法里面,一會兒在后面我們會再詳細(xì)的說如何創(chuàng)建表publicvoidonUpgrade(SQLiteDatabasedb,intoldVersion,intnewVersion)從方法名上我們就能知道這個方法是執(zhí)行更新的,沒錯,當(dāng)version改變是系統(tǒng)會調(diào)用這個方法,所以在這個方法里應(yīng)該執(zhí)行刪除現(xiàn)有表,然后手動調(diào)用onCreate的操作SQLiteDatabasegetReadableDatabase()獲取可讀的SQLiteDatabase對象SQLiteDatabasegetWritabieDatabase()獲取可寫的SQLiteDatabase對象SQLiteDatabase(android,database,sqlite.SQLiteDatabase)關(guān)于操作數(shù)據(jù)庫的工作(增、冊h查、改)都在這個類里execSQL(sql)執(zhí)行SQL語句,用這個方法+SQL語句可以非常方便的執(zhí)行增、刪、查、改除此之外,Android還提供了功過方法實現(xiàn)增、冊h查、改longinsert(TABLE_NAME,null,contentValues)添力口t己錄intdelete(TABLE_NAME,where,whereValue)刪除記錄intupdate(TABLE_NAME,contentvalues,where,whereValue)更新記錄Cursorquery(TABLE_NAME,null,null,null,null,null,null)查詢記錄除此之外,還有很多方法,如:beginTransactionO開始事務(wù)、endTransaction()結(jié)束事務(wù)...有興趣的可以自己看api,這里就不多贅述了Cursor(android.database.Cursor)游標(biāo)(接口),這個很熟悉了吧,Cursor里的方法非常多,常用的有:booleanmoveToPosition(position)將指針移動到某記錄getColumnlndex(Contacts.People.NAME)按列名獲取idint getCount()獲取記錄總數(shù)booleanrequery()重新查詢boolean isAfterLast()指針是否在末尾booleanisBeforeFirst()時候是開始位置boolean isFirst()是否是第一條記錄boolean isLast()是否是最后一條記錄booleanmoveToFirst()> booleanmoveToLast()> booleanmoveToNext()同moveToPosition(position)4>SimpleCursorAdapter(android,widget.Simp1eCursorAdapter)也許你會奇怪了,之前我還說過關(guān)于數(shù)據(jù)庫的操作都在database和database,sqlite包下,為什么把一個Adapter放到這里,如果你用過Android的SQLite3,你一定會知道,這是因為我們對數(shù)據(jù)庫的操作會經(jīng)常跟列表聯(lián)系起來經(jīng)常有朋友會在這出錯,但其實也很簡單Simp1eCursorAdapteradapter=newSimpleCursorAdapter(this,R.layout.list,myCursor,newString:]{DB.TEXT1,DB.TEXT2},newint[]{R.id.listTextViewl,Rid.listTextView2));myListView.setAdapter(adapter);一共5個參數(shù),具體如下:參數(shù)1:Content參數(shù)2:布局參數(shù)3:Cursor游標(biāo)對象參數(shù)4:顯示的字段,傳入String]]參數(shù)5:顯示字段使用的組件,傳入int[],該數(shù)組中是TextView組件的id到這里,關(guān)于數(shù)據(jù)庫的操作就結(jié)束了,但是到目前為止我只做了翻譯的工作,有些同學(xué)可能還是沒有掌握,放心,下面我們一起順著正常開發(fā)的思路理清一下頭緒!前面的只是幫沒做過的朋友做下普及,下面才是你真正需要的!一、寫一個類繼承SQLiteOpenHelpepublicclassDatabaseHelperextendsSQLiteOpenHelper構(gòu)造方法:DatabaseHelper(Contextcontext){super(context,DATABASEJW^null,DATABASE_VERSION);)在onCreate方法里寫建表的操作publicvoidonCreate(SQLiteDatabasedb){Etbtest(idINTEGERDEFAULT'1'NOTNULLPRIMARYKEYAUTOINCREMENT,class_jbTEXTNOTNULL,class_ysbjTEXTNOTNULL,titleTEXTNOTNULL,content_ysbjTEXTNOTNULL)";由ooSI?1);編甥常i獲)在onltgrade方法里刪除現(xiàn)有表燃后手動調(diào)用onCtreate創(chuàng)建表publicvoidonUpgrade(SQLiteDatabasedb,intoldVersion,intnewVersion){db.execSQL(sql);onCreate(db);定義對表增刪、查、改的方法,這里用的是SQLiteOjDeiifelper提供的方法,也可以用sql語句實現(xiàn),都是一樣的關(guān)于獲取可讀/可寫SQLiteDatabase,我不說大家也應(yīng)該會想到,只有查找才會用到可讀的SQLiteDatabase/***添加數(shù)據(jù)*/publiclonginsert(Stringtname,inttage,Stringttel){SQLitdhtabasedb=getWritahleDatabase();//獲取可寫SQLiteDatabase對象//ContentValues類似map,存入的是鍵值對ContentValuescontentValues=newContentValues();putCtiW;tname);omteiOiEsputft^7,t^);(irtel^lLKputCttenttel);retumchinsertmil,contentValues);/***/*****/刪除記錄@param_idpublicvoiddelete(String_id){SCLitdDatabase?getWritableDatabase();db.delete(tbname,〃_id二?〃,tage,Stringttel){getWritableDatabase();newContentValues();〃_id二?〃,tage,Stringttel){getWritableDatabase();newContentValues();("tname”,tname);tage);ttel);{id);/***更新記錄的,跟插入的很像*/publicvoidupdate(Strirg_id,StrijngtraiE,int雙itdhtabasedb=puLCtteHconte:由ipite如陽明artangh耳W,ra^StringD{id);/***查詢所有數(shù)據(jù)*?returnCursor*/publicCursorselect(){getReadableDatabase();S^iteDatabasedb=getReadableDatabase();retimbq£ry(iwString[] “tnanie”,〃tage〃, 〃taddr〃},nil,raWOdesc");}后由qsy用以修數(shù)有f艮多,為了防家弄亂,我簡單說一下參數(shù)1:表名參數(shù)2:返回數(shù)據(jù)包含的列信息,String數(shù)組里放的都是列名參數(shù)3:相當(dāng)于sql里的where,sql里where后寫的內(nèi)容放到這就行了,例如:tage>?參數(shù)4:如果你在參數(shù)3里寫了《知閽戈為什么寫tage>?了吧),那個這里就是代替?的值接上例:newString]]{”30〃}戮(5:分組,不解釋了,不想分姆傳皿1]參數(shù)6:having,想不起來的看看SQL參數(shù)7:orderBy排序到這里,你已經(jīng)完成了代碼最多的第一步!我們來看看都用到了那些類:SQLiteOpenHelper我們繼承使用的SQLiteDatabase增刪查改都離不開它,即使你直接用sql語句,也要用到execSQL(sql)二、這里無非是對DatabaseHelper類定義方法的調(diào)用,沒什么可說的,不過我還是對查詢再嘮叨幾句吧Android查詢出來的結(jié)果一Cursor形式返回cursor=sqLiteHelper.select();〃是不是很簡單?查詢出來的cursor一般會顯示在listView中,這就要用到剛才提到的SimpleCursorAdapterSimpleCursorAdapter(am;newString[]{〃tname〃,,int[]{R.id.TextViewOl,R.id.TextViewO2});是不是很簡單呢,任何復(fù)雜的工程都是通過簡單的代碼實現(xiàn)的.Android數(shù)據(jù)庫操作技巧應(yīng)用http:〃developer.51cto.com2010-01-2616:55佚名CSDN我要評論⑴我們在這篇文章中為大家總結(jié)的Android數(shù)據(jù)庫操作的方式都包括有:創(chuàng)建數(shù)據(jù)庫;操作數(shù)據(jù)庫;數(shù)據(jù)顯示以及導(dǎo)出數(shù)據(jù)庫等等。在Android這樣一個開源的手機(jī)操作系統(tǒng)中,對于數(shù)據(jù)庫的操作是不可避免而且非常重要的。在這里我們就為大家詳細(xì)介紹一下Android數(shù)據(jù)庫操作的一些基本應(yīng)用技巧,以方便大家的學(xué)習(xí)。Android數(shù)字證書具體應(yīng)用機(jī)制Android數(shù)據(jù)存儲訪問機(jī)制Android可選API適用范圍Android調(diào)試程序正確進(jìn)行方式Android根文件系統(tǒng)相關(guān)應(yīng)用介紹Android數(shù)據(jù)庫操作1.創(chuàng)建數(shù)據(jù)庫Android提供了標(biāo)準(zhǔn)的數(shù)據(jù)庫創(chuàng)建方式。繼承SQLiteOpenHelper,實現(xiàn)onCreate和onUpgrade兩個方法,有個好處就是便于數(shù)據(jù)庫版本的升級。privatestaticclassDatabasellelperextendsSQLiteOpenHelper{DatabaseHelper(Contextcontext){super(context,DATABASE_NAME,null,DATABASE_VERSION);}?OverridepublicvoidonCreate(SQLiteDatabasedb){)?OverridepublicvoidonUpgrade(SQLiteDatabasedb,intoldVersion,intnewVersion){))Android數(shù)據(jù)庫操作2.操作數(shù)據(jù)庫之前一直疑惑于一個功能操作是否要每次打開數(shù)據(jù)庫完之后,要立即關(guān)閉數(shù)據(jù)庫?還是一個應(yīng)用程序只開一次數(shù)據(jù)庫,等到應(yīng)用程序退出時再關(guān)閉數(shù)據(jù)庫?其中的顧慮在性能和多線程。想到一個方法,將數(shù)據(jù)庫操作類作為單件,將數(shù)據(jù)庫的lock設(shè)置為false.關(guān)閉數(shù)據(jù)庫的lock.,而在每一個Table的修改時加上相應(yīng)的Table鎖。publicclassWebViewDatabase{publicstaticsynchronizedWebViewDatabasegetlnstance(Contextcontext)//usepertableMutexlock,turnoffdatabaselock,this//improvesperformanceasdatabase5sReentrantLockisexpansivemDatabase.setLockingEnabled(false);//synchronizelocksprivatefinalObjectmHttpAuthLock=newObject();publicbooleanhasHttpAuthUsernamePassword(){synchronized(mHttpAuthLock){returnhasEntries(TABLEJITTPAUTHID);想想看,將將底層數(shù)據(jù)封裝成ContentProvider,供應(yīng)用程序調(diào)用,標(biāo)準(zhǔn)的做法,就是如果對ContentProvider不是很熟悉的話,就有點麻煩了。Android數(shù)字證書具體應(yīng)用機(jī)制Android數(shù)
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025-2030全球PCA輸液泵行業(yè)調(diào)研及趨勢分析報告
- 2025年全球及中國結(jié)構(gòu)型包裝用蜂窩行業(yè)頭部企業(yè)市場占有率及排名調(diào)研報告
- 2025-2030全球自主最后一英里送貨機(jī)器人行業(yè)調(diào)研及趨勢分析報告
- 2025年全球及中國可見光超透鏡行業(yè)頭部企業(yè)市場占有率及排名調(diào)研報告
- 2025-2030全球鈑金沖焊型液力變矩器行業(yè)調(diào)研及趨勢分析報告
- 2025-2030全球教育行業(yè)CRM軟件行業(yè)調(diào)研及趨勢分析報告
- 2025-2030全球艾氏劑行業(yè)調(diào)研及趨勢分析報告
- 2025-2030全球卡車液力變矩器行業(yè)調(diào)研及趨勢分析報告
- 2025年全球及中國鈷鐵合金軟磁材料行業(yè)頭部企業(yè)市場占有率及排名調(diào)研報告
- 2025-2030全球高速RDF制粒機(jī)行業(yè)調(diào)研及趨勢分析報告
- 小學(xué)六年級數(shù)學(xué)上冊《簡便計算》練習(xí)題(310題-附答案)
- 地理標(biāo)志培訓(xùn)課件
- 2023行政主管年終工作報告五篇
- 2024年中國養(yǎng)老產(chǎn)業(yè)商學(xué)研究報告-銀發(fā)經(jīng)濟(jì)專題
- 培訓(xùn)如何上好一堂課
- 高教版2023年中職教科書《語文》(基礎(chǔ)模塊)下冊教案全冊
- 2024醫(yī)療銷售年度計劃
- 稅務(wù)局個人所得稅綜合所得匯算清繳
- 人教版語文1-6年級古詩詞
- 上學(xué)期高二期末語文試卷(含答案)
- 人教版英語七年級上冊閱讀理解專項訓(xùn)練16篇(含答案)
評論
0/150
提交評論