我运行下面的代码:
mDb.beginTransaction();
String updateQuery ="INSERT INTO MAAccounts(userId, accountId, accountType, accountName, parentAccountId, currencyCode, isTransactionDefaultStatusOpen, currentBalance, monthlyBudget, createdOn, updatedOn) VALUES(?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)";
String[] valVars = {
stringToDB(account.userId),
integerToDB(account.accountId).toString(),
integerToDB(account.accountType.getValue()).toString(),
stringToDB(account.accountName),
integerToDB(account.parentAccountId),
stringToDB(account.currencyCode),
boolToDB(account.isTransactionDefaultStatusOpen).toString(),
CurrencyToDB(account.currentBalance).toString(),
CurrencyToDB(account.monthlyBudget).toString(),
dateToDB(now),
"false"};
// Cursor c = mDb.rawQueryWithFactory(null, updateQuery, valVars, null);
Cursor c = mDb.rawQuery(updateQuery, valVars);
try{
mDb.setTransactionSuccessful();
}catch (Exception e){
Log.e("Error in transaction", e.toString());
}finally{
mDb.endTransaction();
c.close();
}
}
cursor 返回null,teh transaction 执行成功,但还是不能存储data 到数据库中。
Primary key 包括 UserId, accountId, 和 accountType。
没有异常记录。哪里出错呢?
在执行插入操作时,如果插入的数据已存在主键冲突,就会导致插入操作失败,但是不会抛出异常。
另外,在调用 mDb.rawQuery() 时,如果查询结果为空,也会返回 null。
因此,在这种情况下,可能是因为插入的数据已存在主键冲突,导致插入操作失败,或者可能是因为调用 rawQuery() 查询结果为空。
你可以尝试在插入数据之前,使用 SELECT 语句检查要插入的数据是否已存在,或者可以使用 INSERT OR IGNORE 语句,在插入数据时忽略主键冲突的情况。
你也可以尝试在调用 rawQuery() 之后,使用 cursor.getCount() 方法来检查查询结果的行数,以确定是否有数据返回。
此外,你也可以在调用 rawQuery() 方法之前,打印出 updateQuery 和 valVars 的值,以帮助你更好地了解问题所在。