热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

android数据存储SQLite

SQLite数据库的特点:轻量级独立隔离跨平台多语言接口安全性SQLite数据类型类型描述NULL这个值为空值VARCHAR(n)长度不固定且其最大长度为n的字串,n不能超过400

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
  • 只检索有用的列、有用的行,越少越好
  • 是否排序
  • 是否创建索引

推荐阅读
  • 在Android开发中,使用Picasso库可以实现对网络图片的等比例缩放。本文介绍了使用Picasso库进行图片缩放的方法,并提供了具体的代码实现。通过获取图片的宽高,计算目标宽度和高度,并创建新图实现等比例缩放。 ... [详细]
  • eclipse学习(第三章:ssh中的Hibernate)——11.Hibernate的缓存(2级缓存,get和load)
    本文介绍了eclipse学习中的第三章内容,主要讲解了ssh中的Hibernate的缓存,包括2级缓存和get方法、load方法的区别。文章还涉及了项目实践和相关知识点的讲解。 ... [详细]
  • 自动轮播,反转播放的ViewPagerAdapter的使用方法和效果展示
    本文介绍了如何使用自动轮播、反转播放的ViewPagerAdapter,并展示了其效果。该ViewPagerAdapter支持无限循环、触摸暂停、切换缩放等功能。同时提供了使用GIF.gif的示例和github地址。通过LoopFragmentPagerAdapter类的getActualCount、getActualItem和getActualPagerTitle方法可以实现自定义的循环效果和标题展示。 ... [详细]
  • 本文介绍了南邮ctf-web的writeup,包括签到题和md5 collision。在CTF比赛和渗透测试中,可以通过查看源代码、代码注释、页面隐藏元素、超链接和HTTP响应头部来寻找flag或提示信息。利用PHP弱类型,可以发现md5('QNKCDZO')='0e830400451993494058024219903391'和md5('240610708')='0e462097431906509019562988736854'。 ... [详细]
  • 1,关于死锁的理解死锁,我们可以简单的理解为是两个线程同时使用同一资源,两个线程又得不到相应的资源而造成永无相互等待的情况。 2,模拟死锁背景介绍:我们创建一个朋友 ... [详细]
  • sklearn数据集库中的常用数据集类型介绍
    本文介绍了sklearn数据集库中常用的数据集类型,包括玩具数据集和样本生成器。其中详细介绍了波士顿房价数据集,包含了波士顿506处房屋的13种不同特征以及房屋价格,适用于回归任务。 ... [详细]
  • 《数据结构》学习笔记3——串匹配算法性能评估
    本文主要讨论串匹配算法的性能评估,包括模式匹配、字符种类数量、算法复杂度等内容。通过借助C++中的头文件和库,可以实现对串的匹配操作。其中蛮力算法的复杂度为O(m*n),通过随机取出长度为m的子串作为模式P,在文本T中进行匹配,统计平均复杂度。对于成功和失败的匹配分别进行测试,分析其平均复杂度。详情请参考相关学习资源。 ... [详细]
  • 动态规划算法的基本步骤及最长递增子序列问题详解
    本文详细介绍了动态规划算法的基本步骤,包括划分阶段、选择状态、决策和状态转移方程,并以最长递增子序列问题为例进行了详细解析。动态规划算法的有效性依赖于问题本身所具有的最优子结构性质和子问题重叠性质。通过将子问题的解保存在一个表中,在以后尽可能多地利用这些子问题的解,从而提高算法的效率。 ... [详细]
  • 高质量SQL书写的30条建议
    本文提供了30条关于优化SQL的建议,包括避免使用select *,使用具体字段,以及使用limit 1等。这些建议是基于实际开发经验总结出来的,旨在帮助读者优化SQL查询。 ... [详细]
  • 本文介绍了Android 7的学习笔记总结,包括最新的移动架构视频、大厂安卓面试真题和项目实战源码讲义。同时还分享了开源的完整内容,并提醒读者在使用FileProvider适配时要注意不同模块的AndroidManfiest.xml中配置的xml文件名必须不同,否则会出现问题。 ... [详细]
  • 开发笔记:Java是如何读取和写入浏览器Cookies的
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了Java是如何读取和写入浏览器Cookies的相关的知识,希望对你有一定的参考价值。首先我 ... [详细]
  • 基于Socket的多个客户端之间的聊天功能实现方法
    本文介绍了基于Socket的多个客户端之间实现聊天功能的方法,包括服务器端的实现和客户端的实现。服务器端通过每个用户的输出流向特定用户发送消息,而客户端通过输入流接收消息。同时,还介绍了相关的实体类和Socket的基本概念。 ... [详细]
  • 本文介绍了一种在PHP中对二维数组根据某个字段进行排序的方法,以年龄字段为例,按照倒序的方式进行排序,并给出了具体的代码实现。 ... [详细]
  • 电话号码的字母组合解题思路和代码示例
    本文介绍了力扣题目《电话号码的字母组合》的解题思路和代码示例。通过使用哈希表和递归求解的方法,可以将给定的电话号码转换为对应的字母组合。详细的解题思路和代码示例可以帮助读者更好地理解和实现该题目。 ... [详细]
  • 如何使用计算机控制遥控车的步骤和电路制作方法
    本文介绍了使用计算机控制遥控车的步骤和电路制作方法。首先,需要检查发送器的连接器和跳线,以确定命令的传递方式。然后,通过连接跳线和地面,将发送器与电池的负极连接,以实现遥控车的前进。接下来,制作一个简单的电路,使用Arduino命令将连接到跳线的电线接地,从而实现将Arduino命令转化为发送器命令。最后,通过焊接晶体管和电阻,完成电路制作。详细的步骤和材料使用方法将在正文中介绍。 ... [详细]
author-avatar
手机用户2502909917
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有