Android数据库操作(一)——基本SQLite命令

1、前言

SQLite数据库系统特点

轻型,嵌入式,ACID关系型数据库

SQLite优缺点
  • 优点:

轻量、高效
绿色无需“安装”
零配置
动态数据类型

  • 缺点:

并发性能
网络文件支持弱
仅支持SQL功能子集,有很多高级的功能不支持

Android平台上的Sqlite数据库用途

APP运行数据的保存,如参数等
离线功能
数据处理

Android平台SQLite使用

  • 具体使用两个类
  • SQLiteDatabase类:封装了管理数据库的各种方法,如insert、delete、update、query
  • SQLiteOpenHelper类:封装了数据库创建和版本管理

2、SQLite命令

本节摘抄自: Android数据库高手秘籍(一)——SQLite命令强烈建议进入原博客查看学习

  • 首先确保模拟器已近连接上了电脑

  • 命令行输入 adb shell 进入控制台,如下图所示:

    《Android数据库操作(一)——基本SQLite命令》 adb shell

注意:#符号表示我们当前已经是超级用户了,如果显示$符号,表示当前只是普通用户而已,这时还需输入su命令切换一下用户身份才行。

  • 有了超级用户权限之后,就可以做很多事情了,如:查看一下系统自带的联系人表
  • 通过命令行 cd data/data 进入到 /data/data目录下,如下图所示:
    《Android数据库操作(一)——基本SQLite命令》 cd data/data

所有应用程序的本地存储文件都是存放在这个目录下面的。

  • 为了要让不同应用程序之间的数据容易区别开来,Android是使用应用程序包名进行分开管理,也就是说每个应用程序的本地存储文件都会存放在自己应用程序包名的那个目录下,
  • 这里我们通过命令行 ls 一下看看有多少子目录:
    《Android数据库操作(一)——基本SQLite命令》 ls

子目录有很多,手机上所有应用程序都在这里,其中 com.android.providers.contacts就是存放联系人的相关数据

  • 通过命令行 cd 包名ls 进入查看该包下的目录:
    《Android数据库操作(一)——基本SQLite命令》 cd 具体包名+ls

可以看到,目前有databases、files、lib和shared_prefs这几个子目录。其中databases肯定是用于存放数据库文件的,files是用于存放普通文本文件的,lib是用于存放so库的,shared_prefs则是用于存放shared文件的,这是Android数据持久化的几种可选方式。

  • 接着进入到databases目录中,再 ls
    《Android数据库操作(一)——基本SQLite命令》 cd databases + ls

其中后缀名为journal的文件是日志文件,我们不用管,contacts2.dbprofile.db才是真正的数据库文件

  • 使用sqlite3命令 sqlite3 数据库文件全名 来打开数据库,如下图所示:

    《Android数据库操作(一)——基本SQLite命令》 sqlite3 数据库文件名

  • 好的,数据库已经打开了,那么我们怎么才能知道当前数据库中有哪些表呢?

  • 输入命令行 .table 就可以查看当前数据库中的表:

    《Android数据库操作(一)——基本SQLite命令》 **.table**

  • 这里有这么多张表?是的,联系人的数据结构非常复杂,很多的数据都是分表存储的。这里我们随便挑一张表,比如说accounts表,如果我想知道这张表中有哪些列应该怎么办呢?在MySQL中可以使用desc accounts这个命令,但SQLite却不认识这个命令,毕竟它们是有差异化的。

  • SQLite中可以使用pragma table_info(TABLE_NAME);这个命令来查看表的数据结构,大致如下图所示:

    《Android数据库操作(一)——基本SQLite命令》 pragma table_info(表名)

  • 可以看到,一共显示了三条结果,表示accounts表中共有三列。但是,所有的字段都缩在了一行里面,并用 “|” 符号分隔,这样我们很难看出每个字段的含义。很简单,只需要换一种显示模式就行了,比如说 line 模式就挺不错的。输入 .mode line 命令切换显示模式,然后重新运行 pragma命令, 结果如下图所示:

    《Android数据库操作(一)——基本SQLite命令》

  • 这样就清晰多了吧?这三列的列名分别是account_name、account_type和data_set,数据类型都是TEXT(字符串),允许为空,并且都不是主键。好,那我现在想查一查accounts表中的数据呢?这就太简单了,使用 select语句 就可以了,如下所示:

    《Android数据库操作(一)——基本SQLite命令》

  • 貌似模拟器上默认就只有一条空数据,如果你用的是手机的话,这里应该就可以查到真正的数据了。不过没关系,我们可以在设置里面手动添加一个邮箱账户,如下图所示:

    《Android数据库操作(一)——基本SQLite命令》

  • 现在再来重新查询一遍accounts表,如下所示:

    《Android数据库操作(一)——基本SQLite命令》 20140901221137578.png

  • 除了查询命令之外,还有其它的增删改命令都和标准的SQL语法是相同的,即insert、delete和update,由于比较简单,不再赘述了。比较值得一提的是,每个SQLite数据库中都还有一个隐藏的sqlite_master表,这里记载了当前数据库中所有表的建表语句,可以使用select * from sqlite_master命令进行查看:

    《Android数据库操作(一)——基本SQLite命令》

  • 结果太多了是不是?一屏根本就显示不下嘛。不要着急,别忘了我们使用的是select命令,可以使用where语句来过滤出我们想要查询的那部分内容,如下图所示:

    《Android数据库操作(一)——基本SQLite命令》

**CREATE TABLE accounts (account_name TEXT, account_type TEXT, data_set TEXT) **这就是accounts表的建表语句了,通过这种方式我们可以查询到任意一张表的建表语句,从而对我们学习和分析数据库表结构有所帮助。

友情提示:

  • 有些朋友可能会觉得,每次都要输入select命令来查询表中的数据太麻烦了。没错,而且还要保证手机是连接在电脑上的时候才能查询,确实太不方便。幸运的是,有些手机软件已经提供了数据库表查询的功能,使得我们随时随地都可以方便地查看数据库中的数据,比如Root Explorer这款软件就不错。
  • 仍然是确保你的手机已经Root,然后安装Root Explorer,打开软件之后按照我们前面介绍的路径,进入/data/data/com.android.providers.contacts/databases,点击contacts2.db数据库,选择内置数据库查看器,然后随便点击一张表就可以查看到里面的数据了,如下图所示:

    《Android数据库操作(一)——基本SQLite命令》

  • 使用这种方法,我们可以随时查看数据库表中的最新数据,直观又方便,在程序开发的时候可以起到非常大的帮助。
    原文作者:_猜火车_
    原文地址: https://www.jianshu.com/p/0452845ec537
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞