软件编程
位置:首页>> 软件编程>> Android编程>> Android中SQLite数据库知识点总结

Android中SQLite数据库知识点总结

作者:laozhang  发布时间:2021-10-03 10:57:13 

标签:Android,SQLite

SQLite 数据库简介

SQLite 是一个轻量级数据库,它是D. Richard Hipp建立的公有领域项目,在2000年发布了第一个版本。它的设计目标是嵌入式的,而且占用资源非常低,在内存中只需要占用几百kB的存储空间,这也是Android移动设备采用SQLite数据库的重要原因之一。

SQLite 是遵守ACID的关系型数据库管理系统。这里的ACID是指数据库事务正确执行的4个基本要素,即原子性(Atomicity)、致性 ( Consistency)、 隔离性( lolation). 持久性( Durabilily )。它能够支持Windows/Linux/UNIX等主流的操作系统,能够跟很多程序语言,例如Tcl、C#、PHP、 Java等相结合。比起Mysql、PostgreSQL 这两款开源数据库管理系统来讲,SQLite的处理速度更快。

SQLite 没有服务器进程,它通过文件保存数据,该文件是跨平台的,可以放在其他平台中使用。并且在保存数据时,支持null(零) 、integer (整数)、real (浮点数字) 、text (字符串文本)和blob(二进制对象)5种数据类型。但实际上SQLite也接收varchar(n)、 char(n)、decimal(p,s)等数据类型,只不过在运算或保存时会转换成对应的5种数据类型。因此,可以将各种类型的数据保存到任何字段中,而不用关心字段声明的数据类型。

SQLite 数据库创建

在Android系统中,创建SQLite数据库是非常简单的。Android系统推荐使用 SQLiteOpenHelper 的子类创建数据库,因此需要创建一个继承自SQLiteOpenHelper,并重写该类中的onCreate()方法和onUpgrade()方法即可。

为什么要使用SQLiteOpenHelper的子类呢,因为SQLiteOpenHelper为抽象类(abstract),必须使用其子类进行继承,同时还需要重写父类的抽象方法,onCreate()方法和onUpgrade()方法都是其父类中的抽象方法。


public class MyHelper extends SQLiteOpenHelper {
 @Override
 private static String DATABASE_NAME = "alan.db";
 private static int DATABASE_VERSION = 2;
 public MyHelper(Context context){
   super(context,DATABASE_NAME,null,DATABASE_VERSION);     //调用父类的构造方法
 }

//数据库第一次被创建时调用该方法
 public void onCreate(SQLiteDatabase db){
   //初始化数据库的表结构,执行一条建表的SQL语句
   db.execSQL("CREATE TABLE IF NOT EXISTS person(_id INTEGER PRIMARY KEY AUTOINCREMENT, name VARCHAR(20), price INTEGER);

}
 //当数据库版本增加时调用
 public void onUpgrade(SQLiteDatabase db,int oldVersion,int newVersion){

}
}

//SQLiteOpenHelper类的构造函数有四个参数
//context代表上下文,name是数据库名字,factory是游标工厂,一般情况下为null值,version是数据库版本,软件在今后的升级中会用到。
public SQLiteOpenHelper(Context context, String name, CursorFactory factory, int version) {
this(context, name, factory, version, null);
}

SQLite 数据库使用

前面介绍了SQLite 数据库及如何创建数据库,接下来将针对SQLite数据库的增、删、改、查操作进行详细讲解。

一、SQLite 基本操作方法 一

1. 增加一条数据

下面以 alan.db 数据库中的person表为例,介绍如何使用 SQLiteDatabase对象的insert()方法向表中插入一条数据,示例代码如下。


public void insert(String name, String price){
 SQLiteDatabase db = myHelper.getWritableDatabase(); //获取可写入的 SQLiteDatabase 对象
 ContentValues values = new ContentValues();  //创建 ContentValues 对象
 values.put("name",name);     //将数据添加到ContentValues对象
 values.put("price",price);
 long id = db.insert("person",null,values); //插入一条数据到person表
 db.close();  //关闭数据库    
}

在上述代码中,通过getWritableDatabase()方 法得到SQLiteDatabase对象,然后获得ContentValues对象并将数据添加到ContentValues对象中,最后调用inser()方法将数据插入到person表中。

insert()方法接收3个参数,第一个参数是数据表的名称,第二个参数表示如果发现将要插入的行为空行时,会将这个列名的值设为null,第三个参数为ContentValues对象。ContentValues类类似于Map类,通过键值对的形式存入数据,这里的key表示插入数据的列名,value 表示要插入的数据。

需要注意的是,使用完SQLiteDatabase对象后定要调用close()方法关闭,否则数据库连接会一直存在,不断消耗内存,当系统内存不足时将获取不到SQLiteDatabase对象,并且会报出数据库未关闭异常。

2. 修改一条数据

下面介绍如何使用SQLiteDatabase的update()方法修改person表中的数据,示例代码如下。


public int update(String name, string price) {
 SQLiteDatabase db = myHelper.getwritableDatabasel;
 ContentValues values = new ContentValues();
 values.put ("price", price);
 int number = db.update("person",values,"name =?",new String[]{name});
 db.close();
 return number;
}

在上述代码中,通过SQLiteDatebase对象db调用update()方法用来修改数据库中的数据,update()方法接收4个参数,第一个参数表示表名,第二个参数接收一个ContentValues对象,第三个参数可选择where语句,第四个参数表示whereClause语句中的占位参数列表,这些字符串会替换掉where条件中的 " ? "。

3. 删除一条数据

下面介绍如何使用SQLiteDatabase的delete()方法修改person表中的数据,示例代码如下。


public int delete(long id) {
  SQLiteDatabase db = myHelper.getwritableDatabasel;
  int number = db.delete("person",_id =?,"name =?",new String[]{id});
  db.close();
  return number;
}

从上述代码中可以看出,删除数据不同于增加和修改数据,因为删除数据不需要ContentValues来添加数据。

4. 查询一条数据

在进行数据查询时使用的是SQLiteDatabase的query0方法,该方法返回的是一个行数集合Cursor。 Cursor 是一个游标接口,提供了遍历查询结果的方法,如移动指针方法move(),获得列值方法getString()等,通过这些方法可以获取集合中的属性值以及序号等。

需要注意的是,在使用完Cursor对象后,一定要及时关闭,否则会造成内存泄露。下面介绍如何使用SQLiteDatabase的query()方法查询数据,示例代码如下。


public boolean find(long id) {
 SQLiteDatabase db = helper .getReadableDatabase ();//获取可读取的 SQLiteDatabase 对象
Cursor cursor = db.query("person", null,“_id =?", new String[]{id}),null, null, null) ; boolean result = cursor.moveToNext () ; cursor.close(); // 关闭游标 db.close() ; return result; }

//Cursor 中的的重要方法:

c.move(int offset); //以当前位置为参考,移动到指定行
c.moveToFirst();  //移动到第一行
c.moveToLast();   //移动到最后一行
c.moveToPosition(int position); //移动到指定行
c.moveToPrevious(); //移动到前一行
c.moveToNext();   //移动到下一行
c.isFirst();    //是否指向第一条
c.isLast();   //是否指向最后一条
c.isBeforeFirst(); //是否指向第一条之前
c.isAfterLast();  //是否指向最后一条之后
c.isNull(int columnIndex); //指定列是否为空(列基数为0)
c.isClosed();    //游标是否已关闭
c.getCount();    //总数据项数
c.getPosition();  //返回当前游标所指向的行数
c.getColumnIndex(String columnName);//返回某列名对应的列索引值,如果不存在返回-1
c.getString(int columnIndex);  //返回当前行指定列的值
c·getColumnIndexOrThrow(String columnName)  //从零开始返回指定列名称,如果不存在将抛出IllegalArgumentException 异常。
c.close() //关闭游标,释放资源

在上述代码中,介绍了使用query()方法查询person表中的数据,query()方法接收7个参数,第一个参数表示表名称,第二个参数表示查询的列名,第三个参数接收查询条件子句,第四个参数接收查询子句对应的条件值,第五个参数表示分组方式,第六个参数接收having条件,即定义组的过滤器,第七个参数表示排序方式。

二、SQLite 基本操作方法 二

这种操作方法类似于执行SQL语句 (语法和SQL server类似)。

1. 增加一条数据


db.execSQL("insert into perosn (name, price) values(?,?)",new String[]{name,price})

2. 修改一条数据


db.execSQL("update person set price =? where name =?", new String[]{price,name});

3. 删除一条数据


db.execSQL("delete from person where _id = ?",new String[]{id});

4. 查询一条数据


Cursor cursor = db.rawQuery("select _id,name,price from person where id =?",new String[]{id});

从上述代码可以看出,查询操作与增、删、改操作有所不同,前面三个操作都是通过execSQL()方法执行SQL语句,而查询操作使用的是rawQuery()方法。这是因为查询数据库会返回一个结果集Cursor,而execSQL()方法则没有返回值。

0
投稿

猜你喜欢

  • Java8Stream流操作List去重根据属性去重整体去重使用distinctArrayList<LabelInfoDTO>
  • 在Java编程中,使用private关键字修饰了某个成员,只有这个成员所在的类和这个类的方法可以使用,其他的类都无法访问到这个private
  • 目录ProxyFactory的工作原理JdkDynamicAopProxy创建代理对象过程JdkDynamicAopProxy创建代理对象执
  • Spring是一个非常流行的Java Web开发框架,它提供了强大的依赖注入、面向切面编程、声明式事务管理等功能,为开发者提供了高效、快速地
  • 一. 多任务和Task、启动模式Android 手机在早期,下方通常会内置三个实体的触摸按键,分别是:桌面、菜单、返回。大概在Android
  • 本文实例讲述了Java集合定义与用法。分享给大家供大家参考,具体如下:java集合大体可分为三类,分别是Set、List和Map,它们都继承
  • 本文实例为大家分享了SpringMVC实现文件上传与下载的具体代码,供大家参考,具体内容如下0.环境准备1.maven依赖<depen
  • SpringBoot启动yaml报错报错找不到org.yaml里的一个方法10:45:54.742 [main] ERROR org.spr
  • 本文实例讲述了Android string.xml中的替换方法。分享给大家供大家参考,具体如下:在android的开发中,经常会遇见一句话,
  • 本文实例为大家分享了ScrollView实现滚动效果的具体代码,供大家参考,具体内容如下如果长文本的内容超过一屏幕 则只能显示一屏幕的内容设
  • 在使用SVN过程中可能有时因为一些原因,不想再使用SVN了,我们想取消与SVN的关联,让Android项目恢复到原始状态,不想有哪些花花绿绿
  • 前言Word中可以针对不同文档排版设计要求来设置背景设置颜色。常见的可设置单一颜色、渐变色或加载图片来设置成背景。下面通过Java来设置以上
  • 一、面向对象的描述面向对象是一种现在最为流行的程序设计方法,几乎现在的所有应用都以面向对象为主了,最早的面向对象的概念实际上是由IBM提出的
  • 一、什么是并查集对于一种数据结构,肯定是有自己的应用场景和特性,那么并查集是处理什么问题的呢?并查集是一种树型的数据结构,用于处理一些不相交
  • 前言想在锁屏上面实现弹窗,第一个想法就是利用 WindowManager 设置 Window 的 Flag,通过设置 Flag 的显示优先级
  • 前言C#本身提供了很强大的控件库,但是很多控件库的功能只是一些基本的功能,就比如最简单的按钮,C#提供了最基础的按钮使用方法,但是如果要增加
  • 前言在我们的日常企业应用开发当中,会碰到很多的图片素材访问的场景。比如社交类应用,您会在朋友圈中存放大量的图片,还有一些在线旅游或者直播的行
  • 开发Android APP微信支付功能,需要完成三个步骤:第一步生成预支付订单、第二步生成微信支付参数、第三步调起微信APP支付。除了需要审
  • Swagger2配置(解决404报错)在spring boot项目中配置Swagger2,配置好了但是访问确实404,SwaggerConf
  • 本文实例为大家分享了C语言实现代码雨效果的具体代码,供大家参考,具体内容如下一、项目描述和最终的效果展示项目:   让字符从上到下
手机版 软件编程 asp之家 www.aspxhome.com