Android 개발 의 SQLite 로 데 이 터 를 저장 하 는 방법 분석
앞에서 말 했 듯 이 sharedreference,sdcard 와 같은 몇 가지 파일 의 조작 은 실제로 Android 에서 또 다른 저장 방식 을 제공 합 니 다.그것 이 바로 sqlite 입 니 다.데이터 베 이 스 를 배 워 서 이것 만 파악 하 는 것 도 문제 없어 요.다음은 나 와 함께 이 걸 해 보 자.
1.안 드 로 이 드 가 생 성 한 데이터 베 이 스 를 열기 위해 SQLiteDeveloper 를 설치 합 니 다.소프트웨어 는 마음대로 검색 하면 찾 을 수 있 습 니 다.뒤에 데이터 베 이 스 를 내 보 내 려 면 소프트웨어 를 열 고'데이터베이스'->'데이터베이스 등록'뒤의 조작 은 스스로 모색 하 는 것 이 좋 습 니 다.
2.업무 클래스 를 작성 하여 데이터베이스 와 데이터베이스 테이블 로 만 듭 니 다.이 클래스 는 다음 과 같 습 니 다.
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
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))"; // sql
db.execSQL(sql); //
}
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
}
}
데이터베이스 와 시계 가 준비 되면 다음 작업 을 할 수 있 습 니 다.3.첨삭,개 조 된 업무 류 작성
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){ // 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()}); //
}
}
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); // , resultset
Student stu;
while(cursor.moveToNext()){ //
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(); //
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);
}
}
주의해 야 할 것 은 getReadable Database 와 getWritable Database 의 용법 입 니 다.단순 한 데이터 조회 만으로 getReadable Database 를 사용 하고 데 이 터 를 수정 하면 후 자 를 사용 합 니 다.또한 sqlite 의 데이터 형식 은 아무런 작용 이 없고 프로그래머 의 상호 협력 을 위 한 것 임 을 주의해 야 한다.4.안 드 로 이 드 를 만 드 는 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()));
}
}
실행 후 데이터 가 생 성 되 었 습 니 다.id 가 11 인 기록 은 삭제 되 었 습 니 다.더 많은 안 드 로 이 드 관련 내용 에 관심 이 있 는 독자 들 은 본 사이트 의 주 제 를 볼 수 있다.
본 고 에서 말 한 것 이 여러분 의 안 드 로 이 드 프로 그래 밍 에 도움 이 되 기 를 바 랍 니 다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Bitrise에서 배포 어플리케이션 설정 테스트하기이 글은 Bitrise 광고 달력의 23일째 글입니다. 자체 또는 당사 등에서 Bitrise 구축 서비스를 사용합니다. 그나저나 며칠 전 Bitrise User Group Meetup #3에서 아래 슬라이드를 발표했...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.