设为首页 收藏本站
查看: 1345|回复: 0

[经验分享] android连接SQLite数据库-----增加改查+分页

[复制链接]

尚未签到

发表于 2016-11-22 10:16:23 | 显示全部楼层 |阅读模式
  SQLite,是一款轻型的数据库,是遵守ACID的关联式数据库管理系统,它的设计目标是嵌入式的,而且目前已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够了。它能够支持Windows/Linux/Unix等等主流的操作系统,同时能够跟很多程序语言相结合,比如 Tcl、C#、PHP、Java等,还有ODBC接口,同样比起Mysql、PostgreSQL这两款开源世界著名的数据库管理系统来讲,它的处理速度比他们都快。SQLite第一个Alpha版本诞生于2000年5月. 至今已经有10个年头,SQLite也迎来了一个版本 SQLite 3已经发布。
还有一件事,大家下载的时候,不要加数据库连接驱动包。本项目是不用的。
先让我们看一下图先。
  
  

DSC0000.jpg




业务类
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);
}

}

  刚学用这个东西,不知道在哪里上传小项目,希望大家告诉我一下。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-303912-1-1.html 上篇帖子: sql复制表定义及复制数据行 下篇帖子: Django源代码阅读分析-2:持久层结构分析
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表