本地数据库的创建和管理是大多数移动应用工程中的核心组件之一,一般会通过直接使用 SQLite 或 Jetpack Room 持久化库来完成。开发者们也在不断地寻求着更好的方式,使其能够在运行中的应用中直接检查和调试数据库。

最新的 Android Studio 4.1 (目前处于 Canary 版本) 内置了叫作 Database Inspector (数据库检查器) 的工具,它可以帮助开发者在已运行的应用中检查、请求以及修改数据库。

△ Database Inspector 可用于修改数据,

就像修改电子表格一样有了 Database Inspector,修改数据库就和编辑电子表格一样简单。如果您使用 Jetpack Room并观察请求结果,对数据库的修改会直接体现在应用里。本文中,我们将会在 Sunflower 应用中使用 Database Inspector 来测试一些边界值用例。Sunflower 是一款园艺类应用,它向开发者展示了基于 Android Jetpack 进行应用开发的最佳实践。所以强烈推荐大家克隆这个代码仓库,并且按照本文的操作尝试一下。

  • Jetpack Room 持久化库https://developer.android.google.cn/topic/libraries/architecture/room
  • 代码仓库https://github.com/android/sunflower

概览

Sunflower 应用的 UI 包含两个标签页。先看一下植物目录标签页,里面列出了可以添加到我的花园的植物。在右上角有一个筛选按钮,点击该按钮会按生长区筛选植物,出现如下列表:

△ 点击该按钮来按照植物生长区筛选植物

可以很直观地看到,这个按钮会根据一些条件来筛选植物。假设我们对整个工程完全不了解,希望通过 Database Inspector 来搞清楚如何实现筛选功能。

从菜单栏依次选择 View > Tool Windows > Database Inspector,就能在 Android Studio 里打开 Database Inspector。初次打开工程的时候,需要静待工程编译完成后即可出现 Database Inspector 的选项。

△ 在菜单栏中依次选择 View > Tool Windows > Database Inspector 来打开 Database Inspector这样就打开了 Database Inspector:△ Database Inspector 窗口

运行 Database Inspector 需要在 API Level 26 或者更高的设备上运行应用,在下拉菜单里选择该应用的进程:

△ 在下拉菜单中选择运行中的应用进程

选择所要检查的应用进程之后,数据库的架构就会出现在下面的面板上。如果要查看 Sunflower 数据库表,需要找到 Databases 并展开 sunflower-db:△ 一旦选择了进程,应用相关的数据库就会列出来回到应用,我们看一下经过筛选的植物列表: 这个列表里有 Avocado (鳄梨)、Grape (葡萄)、Orange (橙子) 和 Tomato (番茄)。如果我按照植物名称进行排序,那么要找 Avocado 的话就会很方便。所以我们可以看看 Database Inspector 可不可以做到这点。首先,双击 Database Inspector 里的 plants 表来显示表里的数据。数据是以默认每页 50 条记录来显示,不过如果数据总数更短,那么每页的结果数量和页数也会发生变化。点击名称列可以让植物表按照名称进行排序。正如我们所想,Avocado 已经排在列表的前面了,它就在数据表的第二行。

请求数据库

看一下 Avocado 的数据输入,在应用中可以使用 growZoneNumber 进行筛选。要验证这一点,我们运行一个请求,将 growZoneNumber 设置为 9,对应结果应该是 Avocado。实际上,这个请求已经在 PlantDao.kt 出现了,我们可以直接通过 Room 的 @Query 注解来调用这个请求。每个 @Query 注解的代码行数旁边都有一个运行小图标。

当我点击运行图标来请求 getPlantsWithGrowZoneNumber() 并且选择对应的数据库的时候,会弹出一个对话框让我们填写: growZoneNumber 的值。

△ 您可以直接通过 @Query 注解来运行请求这里我们输入 9 然后点击 Run 来查看请求结果。除此之外,我们也可以在工具窗口里输入我们自己的请求并运行。这样能够提供更大的自由度,也不会受限于 Dao 接口里的请求语句定义。要运行我们自己的查询语句,点击 Run Query 并且从右侧新打开的标签页选择 plants 数据库。△ 点击 Run Query 并且选择应用数据库然后,在数据库下拉菜单旁边的文本框里输入下面这句查询语句,并点击 RunSelect * from plants where growZoneNumber=9△ 您可以在 Database Inspector 里执行 SQL 请求大家可以看到,这里请求的筛选结果和应用里开启筛选器的时候是一样的。

修改以及调试数据库

Database Inspector 使得调试应用变得轻而易举,它还可以让开发者直接修改设备上已运行应用的数据库值。首先,我想在应用 UI 上测试一下较长的植物名称。我们打算使用 Database Inspector 直接修改数据库里的值,而不是通过修改数据源再刷新数据来进行测试。△ 您可以在 Database Inspector 里编辑数据库现在这里的数据元素已经可以编辑,我将这里的 Apple 改为 A really special type of Apple,然后点确认。如果您也在同步进行操作,您可以输入一些期望长度的名称数据在 UI 中进行测试。△ 如果您的应用使用 Jetpack Room 并且监听请求结果,那么您无需重启应用就能看到数据的变化回到应用会发现我们什么操作都没做,应用就已经显示了最新的数据。如果您的应用使用 Jetpack Room,并且监听着请求结果 (使用 LiveData/Flow),您就没必要发起数据库请求来刷新数据。否则,根据您应用触发请求的方式,可能需要重启应用或者重新打开相关的 activity 或者 fragment 才可以。这也算是迁移到 LiveData 或者 Flow的一个不错的理由,这样也能发挥 Database Inspector 的全部潜能。再来看看应用,可以发现这里的 CardView 并没有很好地显示较长的植物名称。我会在未来修复这个问题,接下来我们先来看看下面的测试。△ 应用并没有很好地处理较长的名字每个植物都有不同的浇水间隔,我想试试看如果错过了浇水的日子会发生什么。要实现这个目的,我们需要在花园里添加一些植物,但是首先,这里我们先在 Database Inspector 里勾选 Live updates (实时刷新)。当启用 Live updates 之后,Database Inspector 会自动显示应用里对数据库所做的修改。△ 选择 Live updates

然后回到我的花园标签页,添加一些植物,比如 Avocado 和 Eggplant,但是首先,回到 Database Inspector,然后双击 garden_plantings 来观察数据表。请注意观察图片,当添加新植物的时候,garden_plantings 表会有哪些变化。

△ Database Inspector 会自动显示数据修改这些植物的浇水周期都是三天。当然我不会等待三天来测试这个功能,这里我们直接编辑数据库,然后修改 last_watering_day 的值。我们再回到 Database Inspector,双击进入 garden_plantings 数据表,last_watering_day 位于数据库的最后一列。我会把两个记录的 last_watering_day 值修改为目前日期稍早一些时候。△ 对数据库的修改会直接展示出来好吧,看上去好像调整的日期有点太靠前了,不过应该也能达到测试的目的。应用的 UI 似乎正常显示了所需浇水的日期。在下一步开发中,我们也许可以增加一个提醒功能,当已经超出浇水日期的时候,可以向用户发出提醒。快来尝试新推出的 Database Inspector!欢迎大家和我们分享心得。如果遇到任何问题,请在这里提出: https://issuetracker.google.com/issues/new?component=192708&template=840533&title=%23database-inspector


推荐阅读

 点击屏末  | 下载最新 Android Studio 4.1 Canary 版本,即刻体验 Database Inspector 工具!


.net中如何同步获取数据方式增加一样数据自动刷新列表_期待已久的动态数据库工具终于来了!...相关推荐

  1. .net中如何同步获取数据方式增加一样数据自动刷新列表_知客CRM如何对接微信公众号...

    如果您的企业正在运营微信公众号,您可以将公众号上的粉丝和知客CRM中的客户信息进行身份绑定,这样公众号的粉丝就有了一个客户ID,能够与CRM系统进行业务交互,比如浏览公司产品.下单到CRM.发起投诉流 ...

  2. html如何获取请求头变量的值。_如何使用 Python 爬取微信公众号文章

    我比较喜欢看公众号,有时遇到一个感兴趣的公众号时,都会感觉相逢恨晚,想一口气看完所有历史文章.但是微信的阅读体验挺不好的,看历史文章得一页页的往后翻,下一次再看时还得重复操作,很是麻烦. 于是便想着能 ...

  3. 手把手教你使用java对接微信公众号-获取地理位置信息

    公众号需要定位当前用户的地址位置,需要通过签名后返回的数据,前端将参数回调到微信服务器获取地理位置信息,官方文档说明(https://developers.weixin.qq.com/doc/offi ...

  4. java 对接微信公众号(一)获取token

    1.登录微信公众平台,在基本配置里获取AppId和AppSecret 2.获取token(token获取到存本地,后续API都要带token访问) 需要在基本配置里配置ip白名单才能获取到token ...

  5. vue项目中对接微信公众号使用微信js-sdk

    首先,确保你安装了weixin-js-sdk. 如果还没有安装 npm install weixin-js-sdk 注意:----在vue项目中引入jssdk,微信为了方便用户使用,将官方的jssdk ...

  6. java 微信群发多图文_能使用Java,在 微信公众号中实现同时给多个用户发送同一个图文消息吗?xml中的fromusername应该怎么填?...

    你调用接口都不监视接口返回的数据么,你这样调用接口会直接返回错误提示 touser就写一个openID 用for循环处理,脑壳别太死板了 public static  void sendall(Lis ...

  7. 利用延时处理实现表单系统数据通过微信公众号自动发送消息提醒

    延时处理是指在流程搭建过程中,在第一个步骤完成后不需要立即开启后续步骤,需要几个小时或者几天后再执行,这时可以利用延时处理功能,来实现数据流程. 如:利用集简云无代码软件集成平台, 连接金数据表单系统 ...

  8. 用户画像在科技期刊微信公众号精准推送中的应用

    闵甜1,2), 孙涛3),赖富饶1,2), 侯湘4) 1)华南理工大学<现代食品科技>编辑部,广东省广州市天河区五山路381号 510640 2)华南理工大学食品科学与工程学院,广东省广州 ...

  9. 微信公众号与用户互动的8种交流方式

    说到微信公众号是现在大家在熟悉不过的了,每个人都会关注那么几个公众号,而现在公众号不管是企业.机构.个人都在运用的一个平台,企业用来传播自己的品牌以及产品的营销,机构.个人注册公众号也是这样一个理,在 ...

最新文章

  1. 【Boost】noncopyable:不可拷贝
  2. Spring Boot开始
  3. XDOJ-1093-一元三次方程
  4. IE报vuex requires a Promise polyfill in this browser问题解决
  5. indigo egit
  6. linux命令--VI命令详解(二)
  7. SpringBoot项目打成jar包后,无法读取resources下的文件
  8. 不当败家子的原因......
  9. mysql创建远程登陆用户并授权
  10. Wootrade宣布加入SushiSwa旗下Mirin协议和子池计划
  11. html基础教程全集零基础入门到精通汇总整理(附详细的学习路线图)
  12. 网易2017校招合唱团
  13. mmdetection训练、测试
  14. Vue Cannot read property ‘xxx‘ of undefined
  15. 基于Red Hat的Linux安装网易云音乐教程(openSUSE)
  16. Speex Acoustic Echo Cancellation (AEC) 回声消除模块的使用
  17. JAVA毕设合集【20套系统项目】
  18. ​​Linux下ps -ef和ps aux的区别及格式详解​
  19. basler 相机取图超时_Opencv打开basler相机——实现显示视频、保存图片、记录视频(Windows下)...
  20. 【计算机系统结构】第2章 计算机指令集结构设计问答题

热门文章

  1. 深度学习Dropout技术分析
  2. 客快物流大数据项目(十六):使用脚本创建镜像
  3. 2021年大数据基础(五):​​​​​​​​​​​​​​​​​​​​​分布式技术
  4. Cocos 物理系统
  5. 报错Failed to initialize JPA EntityManagerFactory: Unable to create requested service解决方法
  6. python 字符串格式化是打印不同类型更简单一些
  7. Android aar 代码查看
  8. Context.getExternalFilesDir()和Context.getExternalCacheDir()
  9. Java this 关键字使用
  10. 浅析 JavaScript 中的 函数 uncurrying 反柯里化