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,如需转载请自行联系原作者

相关文章
|
2月前
|
SQL 开发框架 .NET
ASP.NET连接SQL数据库:详细步骤与最佳实践指南ali01n.xinmi1009fan.com
随着Web开发技术的不断进步,ASP.NET已成为一种非常流行的Web应用程序开发框架。在ASP.NET项目中,我们经常需要与数据库进行交互,特别是SQL数据库。本文将详细介绍如何在ASP.NET项目中连接SQL数据库,并提供最佳实践指南以确保开发过程的稳定性和效率。一、准备工作在开始之前,请确保您
241 3
|
1月前
|
关系型数据库 MySQL 数据库连接
python脚本:连接数据库,检查直播流是否可用
【10月更文挑战第13天】本脚本使用 `mysql-connector-python` 连接MySQL数据库,检查 `live_streams` 表中每个直播流URL的可用性。通过 `requests` 库发送HTTP请求,输出每个URL的检查结果。需安装 `mysql-connector-python` 和 `requests` 库,并配置数据库连接参数。
128 68
|
20天前
|
数据库 C# 开发者
ADO.NET连接到南大通用GBase 8s数据库
ADO.NET连接到南大通用GBase 8s数据库
|
19天前
|
数据库连接 Linux Shell
Linux下ODBC与 南大通用GBase 8s数据库的无缝连接配置指南
本文详细介绍在Linux系统下配置GBase 8s数据库ODBC的过程,涵盖环境变量设置、ODBC配置文件编辑及连接测试等步骤。首先配置数据库环境变量如GBASEDBTDIR、PATH等,接着修改odbcinst.ini和odbc.ini文件,指定驱动路径、数据库名称等信息,最后通过catalog.c工具或isql命令验证ODBC连接是否成功。
|
18天前
|
JSON JavaScript 关系型数据库
node.js连接GBase 8a 数据库 并进行查询代码示例
node.js连接GBase 8a 数据库 并进行查询代码示例
|
1月前
|
SQL Java 数据库连接
在Java应用中,数据库访问常成为性能瓶颈。连接池技术通过预建立并复用数据库连接,有效减少连接开销,提升访问效率
在Java应用中,数据库访问常成为性能瓶颈。连接池技术通过预建立并复用数据库连接,有效减少连接开销,提升访问效率。本文介绍了连接池的工作原理、优势及实现方法,并提供了HikariCP的示例代码。
50 3
|
19天前
|
数据库连接 数据库 C#
Windows下C# 通过ADO.NET方式连接南大通用GBase 8s数据库(上)
Windows下C# 通过ADO.NET方式连接南大通用GBase 8s数据库(上)
|
19天前
|
数据库连接 数据库 C#
Windows下C# 通过ADO.NET方式连接南大通用GBase 8s数据库(下)
本文接续前文,深入讲解了在Windows环境下使用C#和ADO.NET操作南大通用GBase 8s数据库的方法。通过Visual Studio 2022创建项目,添加GBase 8s的DLL引用,并提供了详细的C#代码示例,涵盖数据库连接、表的创建与修改、数据的增删查改等操作,旨在帮助开发者提高数据库管理效率。
|
2月前
|
关系型数据库 MySQL 数据库连接
DBeaver如何连接一个数据库
【10月更文挑战第27天】DBeaver 是一款功能强大的通用数据库管理工具,支持多种主流数据库。本文介绍了使用 DBeaver 连接数据库的基本步骤,包括下载安装、创建新连接、选择数据库类型、配置连接参数、测试连接以及最终连接到数据库。详细的操作指南帮助用户轻松管理和操作数据库。
300 9
|
1月前
|
Java 数据库连接 数据库
深入探讨Java连接池技术如何通过复用数据库连接、减少连接建立和断开的开销,从而显著提升系统性能
在Java应用开发中,数据库操作常成为性能瓶颈。本文通过问题解答形式,深入探讨Java连接池技术如何通过复用数据库连接、减少连接建立和断开的开销,从而显著提升系统性能。文章介绍了连接池的优势、选择和使用方法,以及优化配置的技巧。
34 1