Android开发之使用SQLite存储数据的方法分析
时间:2022-07-28
本文章向大家介绍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) {
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);
}
}
需要注意的是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.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的记录已经被删除了
希望本文所述对大家Android程序设计有所帮助。
- CListCtrl控件使用方法总结
- JavaScript基础考核真题——你能全做对吗?
- 拉手网面试题,不一样的难度
- Html 5 video/audio 格式转换 ogg
- ASP.NET MVC 开源项目Kigg解读(1)
- 一个setInterval的小问题
- scrollLeft等属性介绍
- ASP.NET MVC 开源项目Kigg解读(2)——Kigg.Core第一部分
- JavaScript 实现接口 (Interfaces In JavaScript)
- JavaScript 中的单例模式 (singleton in Javascript)
- asp.net MVC 权限设计
- Mediawiki 生成google sitemap
- Meidawiki 配置
- 利用JavaScript获取浏览器计算后的样式
- java教程
- Java快速入门
- Java 开发环境配置
- Java基本语法
- Java 对象和类
- Java 基本数据类型
- Java 变量类型
- Java 修饰符
- Java 运算符
- Java 循环结构
- Java 分支结构
- Java Number类
- Java Character类
- Java String类
- Java StringBuffer和StringBuilder类
- Java 数组
- Java 日期时间
- Java 正则表达式
- Java 方法
- Java 流(Stream)、文件(File)和IO
- Java 异常处理
- Java 继承
- Java 重写(Override)与重载(Overload)
- Java 多态
- Java 抽象类
- Java 封装
- Java 接口
- Java 包(package)
- Java 数据结构
- Java 集合框架
- Java 泛型
- Java 序列化
- Java 网络编程
- Java 发送邮件
- Java 多线程编程
- Java Applet基础
- Java 文档注释
- 疑似 KimsukyAPT 组织最新攻击活动样本分析
- 查找被删除但仍然占据磁盘的文件
- WPF 获取本机所有字体拿到每个字符的宽度和高度
- WPF 自己封装 Skia 差量绘制控件
- C# dotnet 使用 OpenXml 解析 Word 文件
- Day20:包含min函数的栈
- No module named ‘SerialClient‘和Cannot import package : rosserial_arduino
- 提升开发效率N倍的20+命令行神器!(附 demo)
- Java反射原理
- 【每日一题】46. Permutations
- 免费下论文的10个方法
- 【原创】90%的人都不会做的一道笔试题
- 这10道 Spring 常见面试题,你能搞定吗?
- 网工小白升级打怪篇(二)telnet实现远程管理
- (32)条件判断