Android sqlite cursor的遍歷實(shí)例詳解
查詢并獲得了cursor對(duì)象后,用while(corsor.moveToNext()){}遍歷,當(dāng)corsor.moveToNext()方法調(diào)用,如果發(fā)現(xiàn)沒有對(duì)象,會(huì)返回false
public List<MMImage> getAll() {List<MMImage> list = new ArrayList<MMImage>();Cursor c = null;try { c = database.query(TABLE, null, null, null, null, null, null); while (c.moveToNext()) {MMImage mmImage = getMMImageFromCursor(c);list.add(mmImage); }} catch (Exception e) { e.printStackTrace();} finally { if (c != null) {c.close(); }}return list; }
知識(shí)點(diǎn)內(nèi)容擴(kuò)展:
寫android的時(shí)候,涉及到sqlite的知識(shí),所以自己想搞一個(gè)Demo學(xué)習(xí)一下,看了相關(guān)的教程和幫助文檔,然后開始動(dòng)手寫自己的程序
//1.獲取SQLiteDatabase的對(duì)象SQliteDataBase sqlite = SQliteDatabase.openOrCreateDatabase(new File(Environment.getExternalStorageDirectory() + 'testDB'),null);//2.向數(shù)據(jù)庫中存入數(shù)據(jù)sqlite.execSQL('create table student(id varchar2(10),name varchar2(20),sex varchar2(2)');sqlite.execSQL('insert into student values(?,?,?)', new String[] {'2013111111', 'Tom', 'M' });//3.從sqlite中讀取數(shù)據(jù)Cursor cursor = sqlite.rawQuery('select * from student', null);//輸出列名for (int i = 0; i < cursor.getColumnCount(); i++) { textView.append(cursor.getColumnName(i) + ’t’);}textView.append('n');//開始讀取其中的數(shù)據(jù)if (cursor.moveToFirst()) { do {textView.append(cursor.getString(0) + ’t’ + cursor.getString(1) + ’t’ + cursor.getString(2) + ’n’); } while (cursor.moveToNext());}
看起了很簡單,但是我當(dāng)時(shí)在使用cursor的時(shí)候忘了定位cursor,因?yàn)樵诓樵冎蠓祷氐氖且粋€(gè)結(jié)果集,也就是一張二維表,如果我們直接調(diào)用getString(int ColumnIndex)的話,就會(huì)報(bào)錯(cuò),因?yàn)楣鈽?biāo)不能夠確定你要返回哪一行的數(shù)據(jù),從而我們?cè)谑褂肅ursor的時(shí)候,注意定位光標(biāo)。
以上就是Android sqlite cursor的遍歷實(shí)例詳解的詳細(xì)內(nèi)容,更多關(guān)于Android sqlite cursor的遍歷的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!
相關(guān)文章:
1. python中scrapy處理項(xiàng)目數(shù)據(jù)的實(shí)例分析2. HTML <!DOCTYPE> 標(biāo)簽3. 基于PHP與XML的PDF文檔生成技術(shù)4. 快速搭建Spring Boot+MyBatis的項(xiàng)目IDEA(附源碼下載)5. Python requests庫參數(shù)提交的注意事項(xiàng)總結(jié)6. AJAX的跨域問題解決方案7. 將properties文件的配置設(shè)置為整個(gè)Web應(yīng)用的全局變量實(shí)現(xiàn)方法8. ASP基礎(chǔ)入門第三篇(ASP腳本基礎(chǔ))9. jsp文件下載功能實(shí)現(xiàn)代碼10. WWDC總結(jié):開發(fā)者需要知道的iOS 9 SDK新特性
