Android 개발 의 SQLite 로 데 이 터 를 저장 하 는 방법 분석

5924 단어 AndroidSQLite
이 사례 는 안 드 로 이 드 개발 이 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 인 기록 은 삭제 되 었 습 니 다.


더 많은 안 드 로 이 드 관련 내용 에 관심 이 있 는 독자 들 은 본 사이트 의 주 제 를 볼 수 있다.
본 고 에서 말 한 것 이 여러분 의 안 드 로 이 드 프로 그래 밍 에 도움 이 되 기 를 바 랍 니 다.

좋은 웹페이지 즐겨찾기