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月前
|
关系型数据库 数据库 RDS
【瑶池数据库训练营及解决方案本周精选(探索PolarDB,参与RDS迁移、连接训练营)】(5.30-6.8)
本周精选聚焦数据库迁移训练营、快速连接云数据库RDS训练营及智能多模态搜索解决方案。为用户提供模拟教程与实战演练,学习RDS MySQL实例连接与数据管理技能,助力企业智能化发展。每周解锁数据库实战新场景,抓紧时间,精彩不容错过!
|
4月前
|
关系型数据库 MySQL Java
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
|
3月前
|
安全 Linux 网络安全
YashanDB数据库服务端SSL连接配置
YashanDB支持通过SSL连接确保数据传输安全,需在服务端生成根证书、服务器证书及DH文件,并将根证书提供给客户端以完成身份验证。服务端配置包括使用OpenSSL工具生成证书、设置SSL参数并重启数据库;客户端则需下载根证书并正确配置环境变量与`yasc_env.ini`文件。注意:启用SSL后,所有客户端必须持有根证书才能连接,且SSL与密码认证独立运行。
|
2月前
|
XML 数据库 Android开发
Android数据库的使用(增删改查)
本文介绍了一个简单的数据库操作Demo,包含创建数据库、增删改查功能。通过5个按钮分别实现创建数据库、插入数据、删除数据、更新数据和查询数据的操作。代码结构清晰,适合初学者学习Android SQLite数据库基础操作。
|
2月前
|
数据库 Android开发
Android外部数据库的引用
简介:本文介绍了在Android项目中引用外部数据库的方法。首先,将现成的数据库文件放入项目的`assets`文件夹中(需手动创建)。其次,在APP引导界面通过代码将数据库拷贝至App目录下,确保数据库可用。最后,对数据库进行增删改查等操作。关键步骤包括判断数据库是否存在、使用`AssetManager`读取数据库文件并写入App私有目录,实现外部数据库的顺利集成与使用。
|
2月前
|
数据库 Android开发 开发者
Android常用的room增删改查语句(外部数据库)
本文分享了将一个原生数据库驱动的单词APP重构为使用Room库的过程及遇到的问题,重点解决了Room中增删改查的常用语句实现。文章通过具体示例(以“forget”表为例),详细展示了如何定义实体类、Dao接口、Database类以及Repository和ViewModel的设计与实现。同时,提供了插入、删除、更新和查询数据的代码示例,包括模糊查询、分页加载等功能。此外,针对外部数据库导入问题,作者建议可通过公众号“计蒙不吃鱼”获取更多支持。此内容适合有一定Room基础的开发者深入学习。
Android常用的room增删改查语句(外部数据库)
|
3月前
|
Oracle 安全 关系型数据库
【Oracle】使用Navicat Premium连接Oracle数据库两种方法
以上就是两种使用Navicat Premium连接Oracle数据库的方法介绍,希望对你有所帮助!
666 28
|
3月前
|
SQL 数据库连接 数据库
在C++的QT框架中实现SQLite数据库的连接与操作
以上就是在C++的QT框架中实现SQLite数据库的连接与操作的基本步骤。这些步骤包括创建数据库连接、执行SQL命令、处理查询结果和关闭数据库连接。在实际使用中,你可能需要根据具体的需求来修改这些代码。
211 14
|
数据库 Android开发
Android数据库框架-GreenDao入门,2024年最新flutter 页面跳转动画
Android数据库框架-GreenDao入门,2024年最新flutter 页面跳转动画
Android数据库框架-GreenDao入门,2024年最新flutter 页面跳转动画
|
SQL 存储 数据库
Android数 据库框架该如何选?
大家在 Android 上做数据持久化经常会用到数据库。 本文就这些数据库框架做一个横向对比,供大家在技术选型时做个参考。
405 0
Android数 据库框架该如何选?