Android開發(fā)之使用SQLite存儲(chǔ)數(shù)據(jù)的方法分析
本文實(shí)例講述了Android開發(fā)之使用SQLite存儲(chǔ)數(shù)據(jù)的方法。分享給大家供大家參考,具體如下:
前面已經(jīng)說(shuō)到了幾種文件的操作如sharedreference,sdcard.實(shí)際上Android還提供了另外的存儲(chǔ)方式那就是sqlite。只要學(xué)習(xí)過(guò)數(shù)據(jù)庫(kù)掌握這個(gè)也是沒(méi)問(wèn)題的。下面就和我一起來(lái)弄一下這個(gè)吧。
1. 安裝一個(gè)SQLiteDeveloper,這個(gè)用來(lái)打開android生成的數(shù)據(jù)庫(kù)。軟件隨便搜索就能找到,后面導(dǎo)出數(shù)據(jù)庫(kù)只需打開軟件點(diǎn)擊“數(shù)據(jù)庫(kù)“----->"注冊(cè)數(shù)據(jù)庫(kù)"后面的操作最好自己摸索吧
2. 編寫一個(gè)業(yè)務(wù)類先生成一個(gè)數(shù)據(jù)庫(kù)和數(shù)據(jù)庫(kù)表,這個(gè)類如下所示
package org.lxh.service;
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
import android.database.sqlite.SQLiteOpenHelper;
import android.database.sqlite.SQLiteQueryBuilder;
public class DBService extends SQLiteOpenHelper { //使用SQLiteOpenHelper創(chuàng)建數(shù)據(jù)庫(kù)
public DBService(Context context) {
super(context, "mldn.db", null, 1);
}
public void onCreate(SQLiteDatabase db) {
String sql="create table student(userid Integer primary key autoincrement,username varchar(30))"; //生成數(shù)據(jù)庫(kù)表的sql
db.execSQL(sql); //生成表
}
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
}
}
數(shù)據(jù)庫(kù)和表準(zhǔn)備好之后就可以做下一步的工作了
3. 編寫增刪改查的業(yè)務(wù)類
package org.lxh.service;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import org.lxh.vo.Student;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
public class StudentService {
private DBService db;
public StudentService(Context context){ //構(gòu)造方法實(shí)例化DBService
db=new DBService(context);
}
public void savePerson(List<Student> stu){
String sql="insert into student(username) values(?)";
SQLiteDatabase database=db.getWritableDatabase(); //使用getWritableDatabase取得SQLiteDatabase
Iterator<Student> it=stu.iterator();
while(it.hasNext()){
Student student=it.next();
database.execSQL(sql, new Object[]{student.getUsername()}); //執(zhí)行插入
}
}
public void delete(int userid){
String sql="delete from student where userid=?";
SQLiteDatabase database=db.getWritableDatabase();
database.execSQL(sql, new Object[]{String.valueOf(userid)});
}
public List<Student> fiandAll(){
List<Student> all=new ArrayList<Student>();
String sql="select * from student";
SQLiteDatabase database=db.getReadableDatabase(); //使用getReadableDatabase取得SQLiteDatabase
Cursor cursor=database.rawQuery(sql, null); //得到游標(biāo),類似resultset
Student stu;
while(cursor.moveToNext()){ //移動(dòng)游標(biāo)
int id=cursor.getInt(cursor.getColumnIndex("userid"));
String name=cursor.getString(cursor.getColumnIndex("username"));
stu=new Student();
stu.setUserid(id);
stu.setUsername(name);
all.add(stu);
}
cursor.close(); //關(guān)閉游標(biāo)
return all;
}
public int getCount(){
String sql="select count(*) from student";
SQLiteDatabase database=db.getReadableDatabase();
Cursor cursor=database.rawQuery(sql, null);
cursor.moveToFirst();
return cursor.getInt(0);
}
}
需要注意的是getReadableDatabase和getWritableDatabase的用法,只是單純的數(shù)據(jù)查詢就使用getReadableDatabase,對(duì)數(shù)據(jù)進(jìn)行修改操作就使用后者。另外需要注意sqlite的數(shù)據(jù)類型是沒(méi)有任何作用的,只是為了程序員的互相合作。
4. 編寫android的Junit
package org.lxh.db;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import org.lxh.service.DBService;
import org.lxh.service.StudentService;
import org.lxh.vo.Student;
import android.test.AndroidTestCase;
import android.util.Log;
public class Test extends AndroidTestCase{
public void testSave(){
DBService db=new DBService(this.getContext());
db.getWritableDatabase();
}
public void testSaveStudent(){
StudentService service=new StudentService(this.getContext());
Student stu=null;
List<Student> stus=new ArrayList<Student>();
for(int i=0;i<10;i++){
stu = new Student();
stu.setUsername("陳亞峰"+i);
stus.add(stu);
}
service.savePerson(stus);
}
public void delete(){
StudentService service=new StudentService(this.getContext());
service.delete(11);
}
public void findAll(){
StudentService service=new StudentService(this.getContext());
List<Student> all=service.fiandAll();
Iterator<Student> it=all.iterator();
while(it.hasNext()){
Student stu=it.next();
Log.i("Test", "id:"+stu.getUserid()+","+"username"+stu.getUsername());
}
}
public void findRows(){
StudentService service=new StudentService(this.getContext());
Log.i("Test",String.valueOf(service.getCount()));
}
}
執(zhí)行之后生成了數(shù)據(jù),id為11的記錄已經(jīng)被刪除了


更多關(guān)于Android相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Android操作SQLite數(shù)據(jù)庫(kù)技巧總結(jié)》、《Android數(shù)據(jù)庫(kù)操作技巧總結(jié)》、《Android編程之a(chǎn)ctivity操作技巧總結(jié)》、《Android文件操作技巧匯總》、《Android編程開發(fā)之SD卡操作方法匯總》、《Android開發(fā)入門與進(jìn)階教程》、《Android資源操作技巧匯總》、《Android視圖View技巧總結(jié)》及《Android控件用法總結(jié)》
希望本文所述對(duì)大家Android程序設(shè)計(jì)有所幫助。
- Android Kotlin使用SQLite案例詳解
- android中SQLite使用及特點(diǎn)
- android studio使用SQLiteOpenHelper()建立數(shù)據(jù)庫(kù)的方法
- Android Studio 通過(guò)登錄功能介紹SQLite數(shù)據(jù)庫(kù)的使用流程
- android 中 SQLiteOpenHelper的封裝使用詳解
- Android中SQLite 使用方法詳解
- Android使用SQLite數(shù)據(jù)庫(kù)的示例
- Android開發(fā)中使用sqlite實(shí)現(xiàn)新聞收藏和取消收藏的功能
- Android內(nèi)置SQLite的使用詳細(xì)介紹
相關(guān)文章
Android圖表庫(kù)HelloChart繪制多折線圖
這篇文章主要為大家詳細(xì)介紹了Android圖表庫(kù)HelloChart繪制多折線圖,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-02-02
創(chuàng)建子線程對(duì)Android進(jìn)行網(wǎng)絡(luò)訪問(wèn)
這篇文章介紹了Android中創(chuàng)建子線程進(jìn)行網(wǎng)絡(luò)訪問(wèn)的方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考2021-11-11
Android自定義ViewGroup實(shí)現(xiàn)右滑進(jìn)入詳情
這篇文章主要為大家詳細(xì)介紹了Android如何通過(guò)自定義ViewGroup實(shí)現(xiàn)右滑進(jìn)入詳情效果,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下2023-01-01
Android 點(diǎn)擊屏幕空白處收起輸入法軟鍵盤(手動(dòng)打開)
很多時(shí)候,我們?cè)谑褂脩?yīng)用時(shí),會(huì)出現(xiàn)輸入法軟鍵盤彈出的問(wèn)題,通常情況下,我們默認(rèn)會(huì)使用戶點(diǎn)擊返回鍵或者下一步對(duì)軟鍵盤進(jìn)行隱藏。為了更好的體驗(yàn),我們可以實(shí)現(xiàn)當(dāng)用戶使用完畢軟鍵盤時(shí)。點(diǎn)擊屏幕空白即可實(shí)現(xiàn)收起輸入法軟鍵盤2016-12-12
Android?studio?利用共享存儲(chǔ)進(jìn)行用戶的注冊(cè)和登錄驗(yàn)證功能
這篇文章主要介紹了Android?studio?利用共享存儲(chǔ)進(jìn)行用戶的注冊(cè)和登錄驗(yàn)證功能,包括注冊(cè)頁(yè)面布局及登錄頁(yè)面功能,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2021-12-12
Android 簡(jiǎn)單服務(wù)定位器模式實(shí)現(xiàn)
這篇文章主要介紹了Android 簡(jiǎn)單服務(wù)定位器模式實(shí)現(xiàn),幫助大家更好的理解和學(xué)習(xí)使用Android,感興趣的朋友可以了解下2021-03-03
Android用HandlerThread模擬AsyncTask功能(ThreadTask)
本文主要講用HandlerThread模擬AsyncTask功能,這里提供實(shí)例代碼以便參考,有需要的小伙伴可以參考下2016-07-07

