Android sqlite cursor的遍歷實(shí)例詳解
查詢并獲得了cursor對象后,用while(corsor.moveToNext()){}遍歷,當(dāng)corsor.moveToNext()方法調(diào)用,如果發(fā)現(xiàn)沒有對象,會返回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; }
知識點(diǎn)內(nèi)容擴(kuò)展:
寫android的時候,涉及到sqlite的知識,所以自己想搞一個Demo學(xué)習(xí)一下,看了相關(guān)的教程和幫助文檔,然后開始動手寫自己的程序
//1.獲取SQLiteDatabase的對象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)時在使用cursor的時候忘了定位cursor,因?yàn)樵诓樵冎蠓祷氐氖且粋€結(jié)果集,也就是一張二維表,如果我們直接調(diào)用getString(int ColumnIndex)的話,就會報錯,因?yàn)楣鈽?biāo)不能夠確定你要返回哪一行的數(shù)據(jù),從而我們在使用Cursor的時候,注意定位光標(biāo)。
以上就是Android sqlite cursor的遍歷實(shí)例詳解的詳細(xì)內(nèi)容,更多關(guān)于Android sqlite cursor的遍歷的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!
相關(guān)文章:
1. 基于javaweb+jsp實(shí)現(xiàn)企業(yè)財務(wù)記賬管理系統(tǒng)2. xpath簡介_動力節(jié)點(diǎn)Java學(xué)院整理3. jsp+servlet實(shí)現(xiàn)猜數(shù)字游戲4. 阿里前端開發(fā)中的規(guī)范要求5. .Net Core和RabbitMQ限制循環(huán)消費(fèi)的方法6. CSS hack用法案例詳解7. 解決ajax的delete、put方法接收不到參數(shù)的問題方法8. 使用FormData進(jìn)行Ajax請求上傳文件的實(shí)例代碼9. JavaScript實(shí)現(xiàn)組件化和模塊化方法詳解10. XML解析錯誤:未組織好 的解決辦法
