android连接SQLite数据库-----增加改查+分页

本文介绍了SQLite数据库的特点及其在Android平台上的应用实例。SQLite是一款轻型的、遵守ACID的关联式数据库管理系统,适用于多种操作系统,并能与多种编程语言结合使用。文章通过具体的代码示例展示了如何在Android应用中实现数据的增删改查等功能。
摘要由CSDN通过智能技术生成
SQLite,是一款轻型的数据库,是遵守ACID的关联式 数据库管理系统,它的设计目标是嵌入式的,而且目前已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够了。它能够支持Windows/Linux/Unix等等主流的 操作系统,同时能够跟很多程序语言相结合,比如 Tcl、C#、PHP、Java等,还有ODBC接口,同样比起Mysql、PostgreSQL这两款开源世界著名的数据库管理系统来讲,它的处理速度比他们都快。SQLite第一个 Alpha版本诞生于2000年5月. 至今已经有10个年头,SQLite也迎来了一个版本 SQLite 3已经发布。

还有一件事,大家下载的时候,不要加数据库连接驱动包。本项目是不用的。
先让我们看一下图先。



业务类
package com.smart.dh;
import java.util.Iterator;
import java.util.List;
import android.test.AndroidTestCase;
import android.util.Log;
import com.smart.domain.Person;
import com.smart.service.PersonService;
public class PersonServiceTest extends AndroidTestCase {
private static final String TAG="PersonServiceTest";

//保存数据。
public void testSave() throws Exception{
  PersonService  personService=new PersonService(this.getContext());
//  personService.save(new Person("老梁",(short)23));
  for (int i = 0; i < 10; i++) {
   personService.save(new Person("llb"+i,(short)(i+1)));
  }
  
  
}


//查询
public void testFind() throws Exception{
  PersonService  personService=new PersonService(this.getContext());
  Person person=personService.find(1);
  Log.i(TAG, person.toString());
  
//  personService.save(new Person("老梁",(short)23));
}
//更新语句
public void testUpdate() throws Exception{
  PersonService  personService=new PersonService(this.getContext());
  Person person=personService.find(1);
  person.setName("smart");
  personService.update(person);
  
  Log.i(TAG, person.toString());
  
}
//获得所有的条数
public void testGetCount() throws Exception{
  PersonService  personService=new PersonService(this.getContext());
  Log.i(TAG, String.valueOf(personService.getCount()));
  
}

//分页功能
public void testGetScrollData() throws Exception{
  PersonService  personService=new PersonService(this.getContext());
  List<Person> persons=personService.getScrollData(0, 20);//从0条到20条的数据
  for(Person person:persons){
   Log.i(TAG, person.toString());
  }

}

public void testDelete() throws Exception{
  PersonService  personService=new PersonService(this.getContext());
  personService.delete(1,2,3);//删除1.2.3三条记录
}
}

javaBean类
package com.smart.domain;
public class Person {
@Override
public String toString() {
  
  return "personid="+personid+",name="+name+",age="+age;
}
public int personid;
public String name;
public Short age;
public int getPersonid() {
  return personid;
}
public void setPersonid(int personid) {
  this.personid = personid;
}
public String getName() {
  return name;
}
public void setName(String name) {
  this.name = name;
}
// 增加一个构造器
public Person(int personid, String name, Short age) {
  super();
  this.personid = personid;
  this.name = name;
  this.age = age;
}
//创建构造器
public Person(String name, short age) {
  this.name = name;
  this.age = age;

}
public Short getAge() {
  return age;
}
public void setAge(Short age) {
  this.age = age;
}
}


数据库创建类
package com.smart.service;
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
import android.database.sqlite.SQLiteOpenHelper;
public class DataBaseOpenHelper extends SQLiteOpenHelper {
// 数据名称,
private static final String DBNAME = "smrtDataBase";
// 数据库版本
private static final int version = 1;
// 构造方法参数,
public DataBaseOpenHelper(Context context) {
  super(context, DBNAME, null, version);
}
// 数据库创建表的名子。
@Override
public void onCreate(SQLiteDatabase db) {
  db.execSQL("CREATE TABLE person (personid integer primary key autoincrement,name varchar(20),age INTEGER)");
}
// 更新方法
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
  db.execSQL("EROP TABLE IF EXISTS person");
  onCreate(db);
}
}

转载:http://www.adobex.com/android/source/details/00000012.htm

转载于:https://my.oschina.net/androidcode/blog/103549

一.创建一个DataBaseHelper DataBaseHelper是一个访问SQLite的助类,提供两个方面的功能 1.getReadableDatebase(),getWriteableDatabase()可以获取SQLiteDatabase对象,通过 2.提供了onCreate()和onUpdate()两个回调函数,允许我们常见和升级数据库是进行使用 A、 在SQLiteOpenHelper的子类当中,必须要有的构造函数 B、该函数是在第一次创建数据库的时候执行,实际上是在第一次得到SQLiteDataBase对象的时候onCreate 二、创建一个实体person类并且给字段和封装 三、创建一个业务类对SQL的CRUD操作 1.getWritableDatabase()和getReadableDatabase()的区别 ,两个方法都可以获取一个用于操作数据库SQLiteDatabase实例 2.execSQL(增,删,改都是这个方法)和close();android内部有缓存可关闭也不关闭也行,查询rawQuery是方法 3.在分页有到Cursor(游标)取游标下一个值cursor.moveToNext(),用游标对象接数据 "select * from person limit ?,?" person不能加上where 关键字 4.在删除注意:sb.deleteCharAt(sb.length() - 1); 四、AndroidCRUD业务对SQLite的CRUD操作 1.ContentValues对象的使用 2.android内部insert添加数据的方法,而且values这个不给值也必须要执行,而主键是不是null的其他字段的值是为null 3.insert update query delete 五、单元测试类要注意的 AndroidCRUDService curdService = new AndroidCRUDService(this.getContext()); /* * 注意:getContext必须在我们使用前已经注解进去的,在使用前要实力化,而且是使用后才有上下文 *一般设置为局部对象 */ 六、AndroidManifest.xml的配置 <!-- 配置用户类库android.test.runner测试 --> package jll.sqlitedb; import android.content.Context; import android.database.sqlite.SQLiteDatabase; import android.database.sqlite.SQLiteOpenHelper; import android.database.sqlite.SQLiteDatabase.CursorFactory; /** * *@author Administrator DataBaseHelper是一个访问SQLite的助类,提供两个方面的功能 * 1.getReadableDatebase(),getWriteableDatabase()可以获取SQLiteDatabase对象,通过 * 2.提供了onCreate()和onUpdate()两个回调函数,允许我们常见和升级数据库是进行使用 */ public class DataBaseHelper extends SQLiteOpenHelper { // 给一个默认的SQLite数据库名 private static final String DataBaseName = "SQLite_DB"; private static final int VERSION = 2; // 在SQLiteOpenHelper的子类当中,必须要有的构造函数 public DataBaseHelper(Context context, String name, CursorFacto
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值