我想知道是否可以在同一操作中使用android.content.ContentResolver.applyBatch()方法将master和detail记录保存到内容提供者,其中providers参数中的后续ContentProviderOperation项取决于先前项的结果.
我遇到的问题是,当调用ContentProviderOperation.newInsert(Uri)方法并且Uri是不可变的时,实际的Uri是未知的.
我想出的内容如下所示:
Master Uri:content://com.foobar.masterdetail/master
Detail Uri:content://com.foobar.masterdetail/master/#/detail
ArrayList<ContentProviderOperation> operations = new ArrayList<ContentProviderOperation>();
operations.add(ContentProviderOperation.newInsert(intent.getData())
.withValue(Master.NAME, "")
.withValue(Master.VALUE, "")
.build());
operations.add(ContentProviderOperation.newInsert(intent.getData()
.buildUpon()
.appendPath("#") /* ACTUAL VALUE NOT KNOWN UNTIL MASTER ROW IS SAVED */
.appendPath("detail")
.build())
.withValue(Detail.MASTER_ID, /* WHAT GOES HERE? */)
.withValue(Detail.NAME, "")
.withValue(Detail.VALUE, "")
.build());
ContentProviderResult[] results = this.getContentResolver().applyBatch(MasterDetail.AUTHORITY, operations);
for (ContentProviderResult result : results) {
Uri test = result.uri;
}
Run Code Online (Sandbox Code Playgroud)
在我的内容提供程序中,我重写了applyBatch()方法,以便将操作包装在事务中.
这是可能的还是有更好的方法来做到这一点?
谢谢.
当我在一个全文搜索数据库中插入一行时声明如下:
CREATE VIRTUAL TABLE foo USING fts3 (bar);
Run Code Online (Sandbox Code Playgroud)
SQLiteDatabase.insert()方法返回不正确的rowid.如果表声明如下:
CREATE TABLE foo (bar VARCHAR(10));
Run Code Online (Sandbox Code Playgroud)
它返回正确的rowid值.问题是当我使用从方法返回的rowid插入后很快查询数据库时,返回的Cursor没有记录.它只适用于第一次插入数据库.对于后续插入,将返回不正确的rowid.
我需要做什么才能从SQLiteDatabase.insert()方法中获取正确的rowid?
我正在使用Android SDK版本2.1update1.
谢谢,丹
更新:我最终使用hack使用以下代码获取最后一行id:
private int getLastRowId(SQLiteDatabase db, String table) {
Cursor cursor = null;
try {
cursor = db
.rawQuery(String.format(Locale.US, "SELECT MAX(rowid) FROM %s", table), null);
if (cursor.moveToFirst()) {
return cursor.getInt(0);
} else {
return 0;
}
} finally {
if (cursor != null) {
cursor.close();
}
}
}
Run Code Online (Sandbox Code Playgroud)
就我而言,它是安全的,因为只有一个用户可以访问该应用程序.对于服务应用程序,这可能不起作用,具体取决于它的实现/使用方式.
我相信我们有这个问题,因为在fts3表中执行插入时,会插入多行.在主题表和fts3管理表中也插入了一行.