android – sqlite中query()和rawQuery()之间的区别是什么,哪一个更高效和goog

参见英文答案 > Android SQLite: Which query (“query” or “rawQuery”) is faster?                                    2个
我正在学习在android中实现数据库,我遇到了这个查询()和rawQuery(),我想知道它们之间的区别以及哪一个在android中有效

解决方法:

来自API Doc:

public void execSQL (String sql)

执行一个非SELECT的SQL语句或任何其他返回数据的SQL语句.

public Cursor rawQuery (String sql, String[] selectionArgs)

运行提供的SQL并在结果集上返回Cursor.

如果你想要,例如CREATE TABLE不返回可以使用execSQL()的值,如果你想要一个Cursor作为结果使用rawQuery()(= SELECT语句).

查看android源代码中的SQLiteDatabase.java表明查询(..)最终调用QueryBuilder将查询构建为单个字符串,然后它实质上调用rawQuery().它们应该大致相同,假设您也做了相同的工作来构建自己的语句.

相关文章

SQLite架构简单,又有Json计算能力,有时会承担Json文件/RES...
使用Python操作内置数据库SQLite以及MySQL数据库。
破解微信数据库密码,用python导出微信聊天记录
(Unity)SQLite 是一个软件库,实现了自给自足的、无服务器...
安卓开发,利用SQLite实现登陆注册功能