我正在学习在android中实现数据库,我遇到了这个查询()和rawQuery(),我想知道它们之间的区别以及哪一个在android中有效
来自API Doc:
public void execSQL (String sql)
Run Code Online (Sandbox Code Playgroud)
执行一个非SELECT的SQL语句或任何其他返回数据的SQL语句.
public Cursor rawQuery (String sql, String[] selectionArgs)
Run Code Online (Sandbox Code Playgroud)
运行提供的SQL并在结果集上返回Cursor.
如果你想要CREATE TABLE不返回你可以使用的值execSQL(),如果你想要一个Cursor结果使用rawQuery()(= SELECT语句).
查看android源代码中的SQLiteDatabase.java表明查询(..)最终调用QueryBuilder将查询构建为单个字符串,然后它实质上调用rawQuery().它们应该大致相同,假设您也做了相同的工作来构建自己的语句.
| 归档时间: |
|
| 查看次数: |
10007 次 |
| 最近记录: |