前言
LitePal作为近年来最受欢迎的SQLite操作工具之一,其优势无须赘述。而网络上大量的LitePal使用教程也不需要笔者多言。本文主要解决的就是如何使用LitePal框架操作已经存在的数据库。
作为Android初学者,能够在学习之处就能接触到如此优秀的工具,不得不说,幸运之极。感谢郭霖老师。
我们在开发过程中经常会遇到“使用外部数据库”的需求,但按照通常的先导入外部创建的数据库,再使用Litepal工具的思路时,却发现LitePal完全无法读取。第一反应是哪里代码写错了,网上查找了大量资料,完全没有找到解决办法。但还是找到的原因:LiePal不兼容遗留数据库,只能使用自己创建的数据库。
注意力完全被“数据库必须是由litepal创建”吸引,既然如此,可不可以先使用LitePal创建完整的不填充数据的数据库,然后把数据库导出到电脑,再使用Navicat填充数据?事实证明,我的想法是可以的。
操作步骤
- 使用LitePal工具给项目创建一个其所需的数据库,LitePal使用教程可以参考以下博客:
- 导出数据库到PC,这里需要注意/data/data/packagename/databases/文件夹下存在.db|.db-shm|.db-wal 三个文件,一定要把它们都导出,如果你只导出.db文件你会发现它没有表存在。原因?我,初学者,不知道。
- 使用Navicat Premium导入文件并插入数据。
- 导入数据库到项目,可以参考以下博文:
- 现在你就可以使用LitePal自由操作数据库了:)