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()方法都是其父类中的抽象方法。
 1 public class MyHelper extends SQLiteOpenHelper {
 2     @Override
 3     private static String DATABASE_NAME = "alan.db";
 4     private static int DATABASE_VERSION = 2;
 5     public MyHelper(Context context){
 6         super(context,DATABASE_NAME,null,DATABASE_VERSION);          //调用父类的构造方法
 7     }
 8
 9     //数据库第一次被创建时调用该方法
10     public void onCreate(SQLiteDatabase db){
11         //初始化数据库的表结构,执行一条建表的SQL语句
12         db.execSQL("CREATE TABLE IF NOT EXISTS person(_id INTEGER PRIMARY KEY AUTOINCREMENT, name VARCHAR(20), price INTEGER);
13
14     }
15     //当数据库版本增加时调用
16     public void onUpgrade(SQLiteDatabase db,int oldVersion,int newVersion){
17
18     }
19 }  
1 //SQLiteOpenHelper类的构造函数有四个参数
2 //context代表上下文,name是数据库名字,factory是游标工厂,一般情况下为null值,version是数据库版本,软件在今后的升级中会用到。
3 public SQLiteOpenHelper(Context context, String name, CursorFactory factory, int version) {
4 this(context, name, factory, version, null);
5 }
SQLite 数据库使用
前面介绍了SQLite 数据库及如何创建数据库,接下来将针对SQLite数据库的增、删、改、查操作进行详细讲解。
一、SQLite 基本操作方法 一
1. 增加一条数据
下面以 alan.db 数据库中的person表为例,介绍如何使用 SQLiteDatabase对象的insert()方法向表中插入一条数据,示例代码如下。
1 public void insert(String name, String price){
2     SQLiteDatabase db = myHelper.getWritableDatabase(); //获取可写入的 SQLiteDatabase 对象
3     ContentValues values = new ContentValues();   //创建 ContentValues 对象
4     values.put("name",name);          //将数据添加到ContentValues对象
5     values.put("price",price);
6     long id = db.insert("person",null,values); //插入一条数据到person表
7     db.close();   //关闭数据库
8 }
在上述代码中,通过getWritableDatabase()方 法得到SQLiteDatabase对象,然后获得ContentValues对象并将数据添加到ContentValues对象中,最后调用inser()方法将数据插入到person表中。
insert()方法接收3个参数,第一个参数是数据表的名称,第二个参数表示如果发现将要插入的行为空行时,会将这个列名的值设为null,第三个参数为ContentValues对象。ContentValues类类似于Map类,通过键值对的形式存入数据,这里的key表示插入数据的列名,value 表示要插入的数据。
需要注意的是,使用完SQLiteDatabase对象后定要调用close()方法关闭,否则数据库连接会一直存在,不断消耗内存,当系统内存不足时将获取不到SQLiteDatabase对象,并且会报出数据库未关闭异常。
2. 修改一条数据
下面介绍如何使用SQLiteDatabase的update()方法修改person表中的数据,示例代码如下。
1 public int update(String name, string price) {
2     SQLiteDatabase db = myHelper.getwritableDatabasel;
3     ContentValues values = new ContentValues();
4     values.put ("price", price);
5     int number = db.update("person",values,"name =?",new String[]{name});
6     db.close();
7     return number;
8 }
在上述代码中,通过SQLiteDatebase对象db调用update()方法用来修改数据库中的数据,update()方法接收4个参数,第一个参数表示表名,第二个参数接收一个ContentValues对象,第三个参数可选择where语句,第四个参数表示whereClause语句中的占位参数列表,这些字符串会替换掉where条件中的 " ? "。
3. 删除一条数据
下面介绍如何使用SQLiteDatabase的delete()方法修改person表中的数据,示例代码如下。
1  public int delete(long id) {
2      SQLiteDatabase db = myHelper.getwritableDatabasel;
3      int number = db.delete("person",_id =?,"name =?",new String[]{id});
4      db.close();
5      return number;
6  }
从上述代码中可以看出,删除数据不同于增加和修改数据,因为删除数据不需要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; }
1 //Cursor 中的的重要方法:
2
3 c.move(int offset); //以当前位置为参考,移动到指定行
4 c.moveToFirst(); //移动到第一行
5 c.moveToLast(); //移动到最后一行
6 c.moveToPosition(int position); //移动到指定行
7 c.moveToPrevious(); //移动到前一行
8 c.moveToNext(); //移动到下一行
9 c.isFirst(); //是否指向第一条
10 c.isLast(); //是否指向最后一条
11 c.isBeforeFirst(); //是否指向第一条之前
12 c.isAfterLast(); //是否指向最后一条之后
13 c.isNull(int columnIndex); //指定列是否为空(列基数为0)
14 c.isClosed(); //游标是否已关闭
15 c.getCount(); //总数据项数
16 c.getPosition(); //返回当前游标所指向的行数
17 c.getColumnIndex(String columnName);//返回某列名对应的列索引值,如果不存在返回-1
18 c.getString(int columnIndex); //返回当前行指定列的值
19 c·getColumnIndexOrThrow(String columnName) //从零开始返回指定列名称,如果不存在将抛出IllegalArgumentException 异常。
20 c.close() //关闭游标,释放资源
在上述代码中,介绍了使用query()方法查询person表中的数据,query()方法接收7个参数,第一个参数表示表名称,第二个参数表示查询的列名,第三个参数接收查询条件子句,第四个参数接收查询子句对应的条件值,第五个参数表示分组方式,第六个参数接收having条件,即定义组的过滤器,第七个参数表示排序方式。
二、SQLite 基本操作方法 二
这种操作方法类似于执行SQL语句 (语法和SQL server类似)。
1. 增加一条数据
1 db.execSQL("insert into perosn (name, price) values(?,?)",new String[]{name,price})
2. 修改一条数据
1 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()方法则没有返回值。
Android SQLite 数据库学习的更多相关文章
- Android sqlite数据库存取图片信息
		
Android sqlite数据库存取图片信息 存储图片:bitmap private byte[] getIconData(Bitmap bitmap){ int size = bitmap.get ...
 - Android SQLite 数据库 增删改查操作
		
Android SQLite 数据库 增删改查操作 转载▼ 一.使用嵌入式关系型SQLite数据库存储数据 在Android平台上,集成了一个嵌入式关系型数据库--SQLite,SQLite3支持NU ...
 - Android Sqlite 数据库版本更新
		
Android Sqlite 数据库版本更新 http://87426628.blog.163.com/blog/static/6069361820131069485844/ 1.自己写一个类继承 ...
 - Android SQLite 数据库详细介绍
		
Android SQLite 数据库详细介绍 我们在编写数据库应用软件时,需要考虑这样的问题:因为我们开发的软件可能会安装在很多用户的手机上,如果应用使用到了SQLite数据库,我们必须在用户初次使用 ...
 - 图解IntelliJ IDEA 13版本对Android SQLite数据库的支持
		
IntelliJ IDEA 13版本的重要构建之一是支持Android程序开发.当然对Android SQLite数据库的支持也就成为了Android开发者对IntelliJ IDEA 13版本的绝对 ...
 - Android——SQLite/数据库 相关知识总结贴
		
android SQLite简介 http://www.apkbus.com/android-1780-1-1.html Android SQLite基础 http://www.apkbus.com/ ...
 - 21.Android之SQLite数据库学习
		
Google为Andriod的较大的数据处理提供了SQLite,他在数据存储.管理.维护等各方面都相当出色,功能也非常的强大.SQLite具备下列特点: 1.轻量级 使用 SQLite 只需要带一个动 ...
 - Android数据存储之SQLite 数据库学习
		
Android提供了五种存取数据的方式 (1)SharedPreference,存放较少的五种类型的数据,只能在同一个包内使用,生成XML的格式存放在设备中 (2) SQLite数据库,存放各种数据, ...
 - android: SQLite 数据库的最佳实践
		
6.5.1 使用事务 前面我们已经知道,SQLite 数据库是支持事务的,事务的特性可以保证让某一系列的操 作要么全部完成,要么一个都不会完成.那么在什么情况下才需要使用事务呢?想象以下场 景, ...
 
随机推荐
- 微信小程序开发资源汇总 💯
			
目录 官方文档 工具 插件 讨论 教程 视频教程 文章 代码 轮子 置顶 WePY:组件化的小程序开发框架
 - linux几种时间函数总结
			
一.linux时间函数总结 最近的工作中用到的时间函数比较频繁,今天抽时间总结一下,在linux下,常用的获取时间的函数有如下几个: asctime, ctime, gmtime, localti ...
 - SSM-SpringMVC-19:SpringMVC中请求和响应的乱码解决
			
------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥------------- 配置一道拦截器即可解决乱码 配置方式如下: 在web.xml中: <!--过滤器处理乱码--> ...
 - WPF MVVM  UI分离之《交互与数据分离》
			
在我们使用WPF过程中,不可避免并且超级喜欢使用MVVM框架. 那么,使用MVVM的出发点是视觉与业务逻辑分离,即UI与数据分离 诸如下面的问题: 删除操作,假如需要先执行一部分数据的处理,然后删除界 ...
 - Linux kernel的中断子系统之(四):High level irq event handler
			
返回目录:<ARM-Linux中断系统>. 总结:从架构相关的汇编处理跳转到Machine/控制器相关的handle_arch_irq,generic_handle_irq作为High l ...
 - Sublime Text 3安装SFTP插件
			
前言: 最近在学习网页设计,陆续接触到了HTML.CSS和JavaScript,写的代码越来越多了,也越来越感觉到将代码上传到服务器上的流程太繁琐了.一开始我是用虚拟主机提供的控制面板下载上传网页代码 ...
 - 玩转Spring MVC(二)----MVC框架
			
早期程序员在编写代码时是没有一个规范的,系统的业务逻辑和数据库的访问时混合在一起的,不仅增加了大量的重复工作,而且增加了后期维护的难度. 后来,人们逐渐发现某些通用的功能是可以单独的封装起来的,这样就 ...
 - 【Windows】关于shift跟空格同时按无反应的解决方案
			
在玩游戏中我们经常会遇到各种功能键的使用方法 例如shift跟空格,由于我以前经常要加速大跳,突然发现shift跟空格一起按没有效果,语言设置里也没有相关的快捷键设置到,所以网上查询了一番,至此,问题 ...
 - python画出心形图
			
程序员表达爱的方式真是多种多样.比如,用python来画一个心型,献给梦中的情人,代码如下: from turtle import * pensize(1) pencolor('red') fillc ...
 - GitHub 系列之「向GitHub 提交代码」
			
1.SSH 你拥有了一个 GitHub 账号之后,就可以自由的 clone 或者下载其他项目,也可以创建自己的项目,但是你没法提交代码.仔细想想也知道,肯定不可能随意就能提交代码的,如果随意可以提交代 ...