Android   发布时间:2022-04-28  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了Android开发之使用SQLite存储数据的方法分析大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

本文实例讲述了Android开发之使用sqlite存储数据的方法分享给大家供大家参,具体如下:

前面已经说到了几种文件的操作如sharedreference,sdcard.实际上Android还提供了另外的存储方式那就是sqlite。只要学习过数据库掌握这个也是没问题的。下面就和我一起来弄一下这个吧。

1. 安装一个sqliteDeveloper,这个用来打开android生成数据库。软件随便搜索就能找到,后面导出数据库只需打开软件点击“数据库“----->"注册数据库"后面的操作最好自己摸索吧

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) {
    @R_607_10495@ng 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){
    @R_607_10495@ng 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){
    @R_607_10495@ng sql="delete from student where userid=?";
    sqliteDatabase database=db.getWritableDatabase();
    database.execsql(sql,new Object[]{@R_607_10495@ng.valueOf(userid)});
  }
  public List<student> fiandAll(){
    List<student> all=new ArrayList<student>();
    @R_607_10495@ng 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"));
      @R_607_10495@ng name=cursor.get@R_607_10495@ng(cursor.getcolumnIndex("username"));
      stu=new student();
      stu.setUserid(id);
      stu.setUsername(Name);
      all.add(stu);
    }
    cursor.close(); //关闭游标
    return all;
  }
  public int getCount(){
    @R_607_10495@ng sql="SELEct count(*) from student";
    sqliteDatabase database=db.getReadableDatabase();
    cursor cursor=database.rawQuery(sql,null);
    cursor.moveToFirst();
    return cursor.geTint(0);
  }
}

需要注意的是getReadableDatabase和getWritableDatabase的用法,只是单纯的数据查询就使用getReadableDatabase,对数据进行修改操作就使用后者。另外需要注意sqlite的数据类型是没有任何作用的,只是为了程序员的互相合作。

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.Android@R_616_8932@ase;
import android.util.Log;
public class Test extends Android@R_616_8932@ase{
  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",@R_607_10495@ng.valueOf(service.getCount()));
  }
}

执行之后生成了数据,id为11的记录已经被删除

Android开发之使用SQLite存储数据的方法分析

Android开发之使用SQLite存储数据的方法分析

更多关于Android相关内容感兴趣的读者可查看本站专题:《Android操作SQLite数据库技巧总结》、《Android数据库操作技巧总结》、《Android编程之activity操作技巧总结》、《Android文件操作技巧汇总》、《Android编程开发之SD卡操作方法汇总》、《Android开发入门与进阶教程》、《Android资源操作技巧汇总》、《Android视图View技巧总结》及《Android控件用法总结

希望本文所述对大家Android程序设计有所帮助。

大佬总结

以上是大佬教程为你收集整理的Android开发之使用SQLite存储数据的方法分析全部内容,希望文章能够帮你解决Android开发之使用SQLite存储数据的方法分析所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签: