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

简介:

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);
 }


 

}



本文转自 llb988 51CTO博客,原文链接:http://blog.51cto.com/llb988/486373,如需转载请自行联系原作者

相关文章
|
3月前
|
存储 关系型数据库 MySQL
mysql数据库查询时用到的分页方法有哪些
【8月更文挑战第16天】在MySQL中,实现分页的主要方法包括:1)使用`LIMIT`子句,简单直接但随页数增加性能下降;2)通过子查询优化`LIMIT`分页,提高大页码时的查询效率;3)利用存储过程封装分页逻辑,便于复用但需额外维护;4)借助MySQL变量实现,可能提供更好的性能但实现较复杂。这些方法各有优缺点,可根据实际需求选择适用方案。
360 2
|
2月前
|
SQL JavaScript 数据库
sqlite在Windows环境下安装、使用、node.js连接
sqlite在Windows环境下安装、使用、node.js连接
|
5月前
|
数据库 Android开发 数据安全/隐私保护
在 Android Studio 中结合使用 SQLite 数据库实现简单的注册和登录功能
在 Android Studio 中结合使用 SQLite 数据库实现简单的注册和登录功能
214 2
|
4月前
|
关系型数据库 MySQL 数据库
MybatisPlus添加数据数据库没有数据,数据消失,使用Navicate看不到数据,Navicate中Mysql的数据与idea的数据不一定同步,Navicate与idea的数据库同步,其实有分页
MybatisPlus添加数据数据库没有数据,数据消失,使用Navicate看不到数据,Navicate中Mysql的数据与idea的数据不一定同步,Navicate与idea的数据库同步,其实有分页
|
5月前
|
存储 缓存 数据库
Android之SQLite数据库使用详解
Android之SQLite数据库使用详解
|
5月前
|
存储 数据库 Android开发
在 Android Studio 中结合使用 SQLite 数据库实现简单的注册和登录功能
在 Android Studio 中结合使用 SQLite 数据库实现简单的注册和登录功能
158 0
|
SQL 数据库 Android开发
Android Room联合AsyncListUtil实现RecyclerView分页加载ORM数据
Android Room联合AsyncListUtil实现RecyclerView分页加载ORM数据 我之前写了一系列关于AsyncListUtil实现RecyclerView和ListView的分页加载机制和技术路线,见附录文章4,5。
1482 0
|
1天前
|
XML 存储 Java
探索安卓开发之旅:从新手到专家
【10月更文挑战第35天】在数字化时代,安卓应用的开发成为了一个热门话题。本文旨在通过浅显易懂的语言,带领初学者了解安卓开发的基础知识,同时为有一定经验的开发者提供进阶技巧。我们将一起探讨如何从零开始构建第一个安卓应用,并逐步深入到性能优化和高级功能的实现。无论你是编程新手还是希望提升技能的开发者,这篇文章都将为你提供有价值的指导和灵感。
|
1天前
|
Android开发
布谷语音软件开发:android端语音软件搭建开发教程
语音软件搭建android端语音软件开发教程!
|
9天前
|
编解码 Java Android开发
通义灵码:在安卓开发中提升工作效率的真实应用案例
本文介绍了通义灵码在安卓开发中的应用。作为一名97年的聋人开发者,我在2024年Google Gemma竞赛中获得了冠军,拿下了很多项目竞赛奖励,通义灵码成为我的得力助手。文章详细展示了如何安装通义灵码插件,并通过多个实例说明其在适配国际语言、多种分辨率、业务逻辑开发和编程语言转换等方面的应用,显著提高了开发效率和准确性。
下一篇
无影云桌面