成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術(shù)文章
文章詳情頁

Android sqlite cursor的遍歷實例詳解

瀏覽:161日期:2022-09-17 18:27:42

查詢并獲得了cursor對象后,用while(corsor.moveToNext()){}遍歷,當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; }

知識點內(nèi)容擴展:

寫android的時候,涉及到sqlite的知識,所以自己想搞一個Demo學習一下,看了相關(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());}

看起了很簡單,但是我當時在使用cursor的時候忘了定位cursor,因為在查詢之后返回的是一個結(jié)果集,也就是一張二維表,如果我們直接調(diào)用getString(int ColumnIndex)的話,就會報錯,因為光標不能夠確定你要返回哪一行的數(shù)據(jù),從而我們在使用Cursor的時候,注意定位光標。

以上就是Android sqlite cursor的遍歷實例詳解的詳細內(nèi)容,更多關(guān)于Android sqlite cursor的遍歷的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標簽: Android
相關(guān)文章: