android数据存储--SQLite

SQLite数据库的特点:

  • 轻量级
  • 独立
  • 隔离
  • 跨平台
  • 多语言接口
  • 安全性
SQLite数据类型
类型 描述
NULL 这个值为空值
VARCHAR(n) 长度不固定且其最大长度为 n 的字串,n不能超过 4000。
CHAR(n) 长度固定为n的字串,n不能超过 254。
INTEGER 整数
REAL 所有值都是浮动的数值,被存储为8字节的IEEE浮动标记序号.
TEXT 值为文本字符串,使用数据库编码存储(TUTF-8, UTF-16BE or UTF-16-LE).
BLOB 值是BLOB数据块,以输入的数据格式进行存储。如何输入就如何存储,不改 变格式。
DATE 包含了 年份、月份、日期。
TIME 包含了 小时、分钟、秒。
SQLiteOpenHelper

SQLiteDatabase是一个辅助类。这个类主要用于生成数据库,并对数据库的版本进行管理。

SQLiteOpenHelper (Context context, String name, 
                    SQLiteDatabase.CursorFactory factory, int version)
//第二个参数为database文件名或者为null
//第三个参数为CursorFactory用来创建cursor对象或者为null
//第四个参数为数据库版本号

SQLiteOpenHelper 是一个抽象类,我们通常需要继承它,并且实现里面的2个函数:

  1. onCreate(SQLiteDatabase)方法
public void onCreate(SQLiteDatabase sqLiteDatabase) {
        // create table Orders(Id integer primary key, 
                            CustomName text, OrderPrice integer, Country text);
        String sql = "create table if not exists " + TABLE_NAME + 
                          " (Id integer primary key, CustomName text, 
                                        OrderPrice integer, Country text)";
        sqLiteDatabase.execSQL(sql);
}
  1. onUpgrade (SQLiteDatabase db, int oldVersion, int newVersion)方法
public void onUpgrade(SQLiteDatabase sqLiteDatabase, int oldVersion, int newVersion) {
            String sql = "DROP TABLE IF EXISTS " + TABLE_NAME;
            sqLiteDatabase.execSQL(sql);
            onCreate(sqLiteDatabase);
}
创建数据库
  • 利用SQLiteOpenHelper对象的 getWritableDatabase() 或者
    getReadableDatabase()方法创建或者打开数据库:
//创建DBHelper对象,DBHelper为SQLiteOpenHelper的子类
DBHelper dbHelper = new DBHelper(SQLiteActivity.this,"stu_db",null,1);  
//得到一个可读的SQLiteDatabase对象  
SQLiteDatabase db =dbHelper.getReadableDatabase();  
  • 使用SQLiteDatabase的静态方法
    利用openOrCreateDatabase(String path,SQLiteDatabae.CursorFactory factory)打开或者创建一个数据库
插入数据
  1. 使用SQLiteDatabase的insert(String table,String nullColumnHack,ContentValues values)方法来插入
    使用insert()方法新数据(7, "Jne", 700, "China"),对于修改数据的操作我们一般当作事务(Transaction)处理:
db = DBHelper.getWritableDatabase();
db.beginTransaction();
.
ContentValues contentValues = new ContentValues();
contentValues.put("Id", 7);
contentValues.put("CustomName", "Jne");
contentValues.put("OrderPrice", 700);
contentValues.put("Country", "China");
.
db.insertOrThrow(OrderDBHelper.TABLE_NAME, null, contentValues);
//返回新插入的记录的行号
db.setTransactionSuccessful();
db.endTransaction();

ContentValues内部实现为HashMap,但是两者还是有差别的,ContenValues Key只能是String类型,Value只能存储基本类型的数据,像string,int之类的,不能存储对象。

  1. 编写插入数据的SQL语句,直接调用SQLiteDatabase的execSQL()方法来执行
String sql = "insert into Orders(Id, CustomName, OrderPrice, Country) 
                                         values (7, "Jne", 700, "China");"
db.execSQL(sql);  
删除数据
  1. 调用SQLiteDatabase的
    delete(String table,String whereClause,String[] whereArgs)方法
    (参数一是表名称,参数二是删除条件,参数三是删除条件值数组)
db = DBHelper.getWritableDatabase();
db.beginTransaction();
// delete from Orders where Id in (7,8)
db.delete(OrderDBHelper.TABLE_NAME, "Id = ?", new String[]{"7", "8"});
db.setTransactionSuccessful();
  1. 编写插入数据的SQL语句,直接调用SQLiteDatabase的execSQL()方法来执行
修改数据

调用SQLiteDatabase的
update(String table,ContentValues values,String whereClause, String[] whereArgs)
方法。(第一个参数是表名称,第二个参数是ContentValues类型的键值对,第三个参数是更新条件(where字句),第四个参数是更新条件数组。)

db = DBHelper.getWritableDatabase();
db.beginTransaction();

// update Orders set OrderPrice = 800 where Id = 6
ContentValues cv = new ContentValues();
cv.put("OrderPrice", 800);
db.update(OrderDBHelper.TABLE_NAME, cv, "Id = ?", new String[]{String.valueOf(6)});
db.setTransactionSuccessful();
查询数据

在Android中查询数据是通过Cursor类来实现的,当我们使用SQLiteDatabase.query()方法时,会得到一个Cursor对象,Cursor指向的就是每一条数据。

public Cursor query(String table,String[] columns,String selection,
                    String[] selectionArgs,String groupBy,
                    String having,String orderBy,String limit);

① table: 表名称
② columns: 列名称数组
③ selection: 条件字句,相当于where
④ selectionArgs: 条件字句,参数数组
⑤ groupBy: 分组列
⑥ having: 分组条件
⑦ orderBy: 排序列
⑧ limit: 分页查询限制
⑨ Cursor: 返回值,相当于结果集ResultSet

Cursor是一个游标接口,提供了遍历查询结果的方法。Cursor游标常用方法如下:

方法名称 方法描述
getCount() 获得总的数据项数
isFirst() 判断是否第一条记录
isLast() 判断是否最后一条记录
moveToFirst() 移动到第一条记录
moveToLast() 移动到最后一条记录
move(int offset) 移动到指定记录
moveToNext() 移动到下一条记录
moveToPrevious() 移动到上一条记录
getColumnIndexOrThrow(String columnName) 根据列名称获得列索引
getInt(int columnIndex) 获得指定列索引的int类型值
getString(int columnIndex) 获得指定列缩影的String类型值
db = DBHelper.getReadableDatabase();

// select * from Orders where CustomName = 'Bor'
cursor = db.query(OrderDBHelper.TABLE_NAME, ORDER_COLUMNS, "CustomName = ?",
                    new String[] {"Bor"}, null, null, null);
int count = cursor.getcount();
优化
  • 使用原始SQL语句执行效率更高,如execSQL、rawQuery
  • 只检索有用的列、有用的行,越少越好
  • 是否排序
  • 是否创建索引
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,905评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,140评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,791评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,483评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,476评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,516评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,905评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,560评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,778评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,557评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,635评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,338评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,925评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,898评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,142评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,818评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,347评论 2 342

推荐阅读更多精彩内容

  • 一、环境 安卓系统:4.2 操作系统:Win 8.1 工具:Android Studio 二、SQLite操作 新...
    谷鸽不爱吃稻谷阅读 568评论 0 2
  • 持久化技术 指将用户产生的数据,存储到手机中,即使手机关机数据也不会丢失。Android有文件存储、ShardPr...
    figure_ai阅读 1,134评论 0 1
  • 傲娇病娇绝代双骄 小黄人朝这边奔跑过来的样子真的凶吗?眼睛里满是火光,小明看到了,刚想打招呼,小红就突然被脚下的一...
    不像话的故事阅读 334评论 0 0
  • 不要被玫瑰和甜言蜜语所欺骗,背后有可能隐藏的,只是一个人的私欲和贪婪。不要随随便便接受一个人的好处和礼物,那些所谓...
    独语斜阑1阅读 145评论 0 0
  • 前几天和往常一样打开微博 准备找些素材 更新一条博文 在可能感兴趣的人一栏 发现了一个叫周文刚的ID 随意的点进去...
    病鹿阅读 642评论 2 51