Android数据库代码优化(1) - 从Google的数据库guide说起

本文针对初学者在Android应用中使用SQLite数据库时常见的错误进行总结,包括内存泄漏、异常处理、性能优化等方面的问题,并提出改进措施。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

假如我们没有任何在Android上使用SQLite的经验,现在要开始在工作中用SQLite存储一些数据。OK, 我们去看google的官方培训文档吧,http://developer.android.com/training/basics/data-storage/databases.html
差不多有个5分钟到15分钟吧,这篇官方培训文档就看完了,然后就可以在应用中使用了,它提示的几个Note我们也都注意到了,没犯任何错误。这时候写出来的代码是什么下场呢?
首先是内存泄漏吧,教程没有教用try…finally关Cursor的好习惯,甚至都没提关Cursor这事儿。
其次crash肯定不少,教程里对于execSQL,getWritableDatabase这些容易出exception的语句,没给要加try…catch的提示。
第三你会习惯用getColumnIndexOrThrow吧?会想到其实直接传个常数进去就可以了么?

long itemId = cursor.getLong(cursor.getColumnIndexOrThrow(FeedEntry._ID));

第四,你能想到SQLite的特色功能自动解决冲突有个insertWithOnConflict方法可以调么?自己写select多查一次性能受影响吧?insert出exception会影响性能吧?
第五,update和delete用ID的时候还用LIKE语句?SQLite的索引是不支持LIKE的,生怕能用上索引加快点速度么。。。

String selection =FeedEntry.COLUMN_NAME_ENTRY_ID +" LIKE ?";

看了很多讲优化的书和网上的文章,似乎针对于Android上的SQLite部分关注得都比较少. 下面我们就来共同探讨一下这些问题.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Jtag特工

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值