SQLiteDatabase 基本操作
一、SQLiteOpenHelper类
android 提供类SQLiteOpenHelper帮助用户简化对SQLite数据库的操作。该类是一个抽象类,必须用户自己实现并重写oncreate()和onUpGrade()方法;此外,还必须重写构造方法。构造方法包括上下文,数据库名称,版本等形参。
SQLiteOpenHelper提供两个方法获取数据库:getWriteableDatabase()方法,和getReadableDatabase(),这两个方法都返回一个SQliteDatabase对象,如果该对象不存在就调用onCreate方法创建一个。
二、SQLiteDatabase
获取到SQLiteDatabase后可以任意操纵数据库了,
2.1 调用execSQL("xxx")直接执行SQL命令,例如:
execSQL(“create table book(id integer primary key autouincrement, author text, price real,pages integer)”)创建一张名为book的表格。
execSQL(" drop table if exists book")如果book表存在就删除它。
insert(“book”,null ,contentValue),向book表中添加数据,数据由contentValue描述。contentValue 有很多put方法,接收一个键与对应的值,其中键为表中的列。
2.2 向表中添加数据
insert(“book”,null ,contentValue),向book表中添加数据,数据由contentValue描述。contentValue 有很多put方法,接收一个键与对应的值,其中键为表中的列。
2.3 更新表中的数据
updata("book","data","name = ?",new String(“the lost symbol”)),第一个参数指定要更新数据的表,第二个参数指定要更新的参数,对应列,第三个参数和第四个参数描述要删除的行。其中?是占位符,可以用地四个参数的内容指定其值。第三个参数相当于where。
2.4 删除表中的数据
delete("book","pages>?","500"),第一个参数对应操作的表,第二个和第三个参数描述要删除数据的行。
2.5 查询数据
SQLiteDatabase 提供一个query()方法对数据进行查询,不过query方法比较复杂。query主要包含以下参数:
参数 对应SQL部分 描述
table from table_name 指定查询的表名
columns select column1 columns 指定查询的列名
selection where column=value 指定where的约束条件
selection Args ------------------- 为where中的占位符提供具体的值
groupBy group by column 指定需要group by 的列
having having column=value 对group by 的结果进一步的约束
orderBy order by column1,column2指定查询结果的排序方式
调用query()方法后将返回一个Cursor对象,查询到的所有数据都将从这个对象中取出。
例如:
Cursor cursor = db.query("book",null,null,null,null,null,null);
if (cursor.moveToFirst()){
do {
String name = cursor.getString(cursor.getColumnIndex("name"));
String author = cursor.getString(cursor.getColumnIndex("author"));
int pages = cursor.getInt(cursor.getColumnIndex("pages"));
float price = cursor.getFloat(cursor.getColumnIndex("price"));
Log.d("MainActivity","书名" +name);
Log.d("MainActivity","作者" +author);
Log.d("MainActivity","页数" +pages);
Log.d("MainActivity","价格" +price);
}while (cursor.moveToNext());
cursor.close();
}
三、使用SQL操作数据库
直接使用SQL操作数据库,示例:
3.1 添加数据
db.execSQL("insert into book (name ,author,pages,price) values(?,?,?,?)",new String[]{"The Da vinci Code","Dan Brown","520","19.9"});
3.2 更新数据
db.execSQL("updata book set price = ?where name = ?",new String[]{"9.9","The Da vinci Code"});
3.3 删除数据
db.execSQL(“delete from book where pages>? where name = ?”,new String[]{"500","The Da vinci Code"});
3.4 查询数据
db.rawQuery("select * from book",null);
SQLiteDatabase 基本操作的更多相关文章
- Android Sqlite 工具类封装
鉴于经常使用 Sqlite 数据库做数据持久化处理,进行了一点封装,方便使用. 该封装类主要支持一下功能 支持多用户数据储存 支持 Sqlite数据库升级 支持传入 Sql 语句建表 支持 SQLit ...
- android SQLite数据库的基本操作
SQLite是Android使用的轻量级的数据库,开发Android应用是对数据库的操作自然是必不可少. Android提供了一个SQLiteOpenHelper类来可以很方便的操作数据库, 继承和扩 ...
- android 使用SQLite的基本操作
Android操作数据库SQLite使用sql语句基本操作 1:自定义自己的SQLiteOpenHelper public class DBHelper extends SQLiteOpenHelpe ...
- Key/Value之王Memcached初探:二、Memcached在.Net中的基本操作
一.Memcached ClientLib For .Net 首先,不得不说,许多语言都实现了连接Memcached的客户端,其中以Perl.PHP为主. 仅仅memcached网站上列出的语言就有: ...
- Android Notification 详解(一)——基本操作
Android Notification 详解(一)--基本操作 版权声明:本文为博主原创文章,未经博主允许不得转载. 微博:厉圣杰 源码:AndroidDemo/Notification 文中如有纰 ...
- Android Notification 详解——基本操作
Android Notification 详解 版权声明:本文为博主原创文章,未经博主允许不得转载. 前几天项目中有用到 Android 通知相关的内容,索性把 Android Notificatio ...
- 三、Redis基本操作——List
小喵的唠叨话:前面我们介绍了Redis的string的数据结构的原理和操作.当时我们提到Redis的键值对不仅仅是字符串.而这次我们就要介绍Redis的第二个数据结构了,List(链表).由于List ...
- 二、Redis基本操作——String(实战篇)
小喵万万没想到,上一篇博客,居然已经被阅读600次了!!!让小喵感觉压力颇大.万一有写错的地方,岂不是会误导很多筒子们.所以,恳请大家,如果看到小喵的博客有什么不对的地方,请尽快指正!谢谢! 小喵的唠 ...
- 一、Redis基本操作——String(原理篇)
小喵的唠叨话:最近京东图书大减价,小喵手痒了就买了本<Redis设计与实现>[1]来看看.这里权当小喵看书的笔记啦.这一系列的模式,主要是先介绍Redis的实现原理(可能很大一部分会直接照 ...
随机推荐
- paper 131:【图像算法】图像特征:GLCM【转载】
转载地址:http://www.cnblogs.com/skyseraph/archive/2011/08/27/2155776.html 一 原理 1 概念:GLCM,即灰度共生矩阵,GLCM是一个 ...
- http 中定义的八种请求的介绍
在http1.1协议中,共定义了8种可以向服务器发起的请求(这些请求也叫做方法或动作),本文对这八种请求做出简要的介绍: 1.PUT:put的本义是推送 这个请求的含义就是推送某个资源到服务器,相当于 ...
- Evolution项目(1)
Evolution项目是基于NFine修改的项目 主要改动为: 支持了.net core 1.0 支持了 EF core 1.0 支持数据库自动创建及Demo数据自动灌入 修改了授权方式 新增加了一个 ...
- UITableViewCell内放置复杂结构的subview,但subview中的Button不响应点击事件
原因可能是subview的frame没设置或者不对,这种情况下subview的内容依然正常显示,但是无法接收点击响应的消息. 具体来说就是缺少了下面这句代码: // subview - (id)ini ...
- 阿里yum源
转:http://mirrors.aliyun.com/help/centos?spm=5176.bbsr150321.0.0.d6ykiD 1.备份 mv /etc/yum.repos.d/Cent ...
- <基督教福音视频>
<信耶稣还是罪人吗?>全集 http://www.youku.com/playlist_show/id_18458615.html <因信称义>全集 http://www.yo ...
- 使用netty4.x客户端接收较大数据量报文时发生的读取不完整bug修复记录
1.先说问题 背景:服务是运行在Linux上的安全网关提供的,TCP协议发送 通过二进制编码的xml字符串 报文,报文头的第一个字段是int类型的表示字节序标记,第二个字段是int类型的表示整个报文长 ...
- PHP中include()与require()
引用文件的方法有两种:require 及 include. require 的使用方法如 require("file.php"); .这个函数通常放在 PHP 程序的最前面,PHP ...
- UIApplication
1.UIApplication 是 iPhone 应用程序的开始并且负责初始化并显示 UIWindow,并负责加载应用程序的第一个 UIView 到 UIWindow 窗体中. UIApplicati ...
- linux中断处理原理分析
Tasklet作为一种新机制,显然可以承担更多的优点.正好这时候SMP越来越火了,因此又在tasklet中加入了SMP机制,保证同种中断只能在一个cpu上执行.在软中断时代,显然没有这种考虑.因此同一 ...