日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁 > 芯聞號 > 充電吧
[導(dǎo)讀]大家好,好久沒有更新博客了,最近由于身體不適讓大家久等了,好了,直接進(jìn)入主題~Android 提供了三種數(shù)據(jù)存儲方式,第一種是文件存儲;第二種是SharedPreferences 存儲;第三種就是數(shù)據(jù)

大家好,好久沒有更新博客了,最近由于身體不適讓大家久等了,好了,直接進(jìn)入主題~

Android 提供了三種數(shù)據(jù)存儲方式,第一種是文件存儲;第二種是SharedPreferences 存儲;第三種就是數(shù)據(jù)庫SQLiteDatabase 存儲。

文件存儲我就不用多說了,而SharedPreferences 可以存取簡單的數(shù)據(jù)(int,double,float.etc),它經(jīng)常用于數(shù)據(jù)緩存,因?yàn)樗x取存儲簡單。詳細(xì)可以參見本系列。Android 高手進(jìn)階教程(七)之----Android 中Preferences的使用!

今天我們將講一下SQLiteDatabase 的使用。 而掌握SqliteDatabase ,將會我們接下來掌握ContentProvider 打下良好的基石。

為了讓大家更好的掌握,我們手把手完成該節(jié)的Demo 。

第一步:新建一個(gè)Android工程,命名為SQLiteDatabaseDemo.


第二步:創(chuàng)建一個(gè)新的類BooksDB.java?這個(gè)類要繼承于android.database.sqlite.SQLiteOpenHelper抽象類,我們要實(shí)現(xiàn)其中兩個(gè)方法:onCreate(),onUpdate.具體代碼如下:


[java]?view plaincopy package?com.android.tutor;???import?android.content.ContentValues;???import?android.content.Context;???import?android.database.Cursor;???import?android.database.sqlite.SQLiteDatabase;???import?android.database.sqlite.SQLiteOpenHelper;???public?class?BooksDB?extends?SQLiteOpenHelper?{?????????private?final?static?String?DATABASE_NAME?=?"BOOKS.db";?????????private?final?static?int?DATABASE_VERSION?=?1;?????????private?final?static?String?TABLE_NAME?=?"books_table";?????????public?final?static?String?BOOK_ID?=?"book_id";?????????public?final?static?String?BOOK_NAME?=?"book_name";?????????public?final?static?String?BOOK_AUTHOR?=?"book_author";??????????????????public?BooksDB(Context?context)?{???????????//?TODO?Auto-generated?constructor?stub?????????????super(context,?DATABASE_NAME,?null,?DATABASE_VERSION);???????}???????//創(chuàng)建table???????@Override??????public?void?onCreate(SQLiteDatabase?db)?{?????????????String?sql?=?"CREATE?TABLE?"?+?TABLE_NAME?+?"?("?+?BOOK_ID???????????????+?"?INTEGER?primary?key?autoincrement,?"?+?BOOK_NAME?+?"?text,?"+??BOOK_AUTHOR?+"?text);";?????????????db.execSQL(sql);???????}???????@Override??????public?void?onUpgrade(SQLiteDatabase?db,?int?oldVersion,?int?newVersion)?{???????????String?sql?=?"DROP?TABLE?IF?EXISTS?"?+?TABLE_NAME;???????????db.execSQL(sql);???????????onCreate(db);???????}??????????????public?Cursor?select()?{???????????SQLiteDatabase?db?=?this.getReadableDatabase();???????????Cursor?cursor?=?db???????????????????.query(TABLE_NAME,?null,?null,?null,?null,?null,?null);???????????return?cursor;???????}???????//增加操作????????public?long?insert(String?bookname,String?author)?????????{???????????SQLiteDatabase?db?=?this.getWritableDatabase();???????????/*?ContentValues?*/??????????ContentValues?cv?=?new?ContentValues();???????????cv.put(BOOK_NAME,?bookname);???????????cv.put(BOOK_AUTHOR,?author);???????????long?row?=?db.insert(TABLE_NAME,?null,?cv);???????????return?row;?????????}????????//刪除操作?????????public?void?delete(int?id)?????????{???????????SQLiteDatabase?db?=?this.getWritableDatabase();???????????String?where?=?BOOK_ID?+?"?=??";???????????String[]?whereValue?={?Integer.toString(id)?};???????????db.delete(TABLE_NAME,?where,?whereValue);?????????}?????????//修改操作?????????public?void?update(int?id,?String?bookname,String?author)?????????{???????????SQLiteDatabase?db?=?this.getWritableDatabase();???????????String?where?=?BOOK_ID?+?"?=??";???????????String[]?whereValue?=?{?Integer.toString(id)?};????????????????????ContentValues?cv?=?new?ContentValues();???????????cv.put(BOOK_NAME,?bookname);???????????cv.put(BOOK_AUTHOR,?author);???????????db.update(TABLE_NAME,?cv,?where,?whereValue);?????????}???}????


第三步:修改main.xml布局如下,由兩個(gè)EditText和一個(gè)ListView組成,代碼如下:


[c-sharp]?view plaincopy

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時(shí)聯(lián)系本站刪除( 郵箱:macysun@21ic.com )。
換一批
延伸閱讀
關(guān)閉