我正在学习在android中实现数据库,我遇到了这个查询()和rawQuery(),我想知道它们之间的区别以及哪一个在android中有效
答案 0 :(得分:7)
来自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
不会返回您可以使用{{1}}的值。
查看android源代码中的SQLiteDatabase.java表明查询(..)最终调用QueryBuilder将查询构建为单个字符串,然后它实质上调用rawQuery()。它们应该大致相同,假设你也做了同样的工作来构建你自己的陈述。