SLaks 2013-06-06 03:17 采纳率: 0%
浏览 940

数据库中不能存储 query

我运行下面的代码:

   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。
没有异常记录。哪里出错呢?

  • 写回答

1条回答 默认 最新

  • ChatGPTᴼᴾᴱᴺᴬᴵ 2022-12-26 20:30
    关注

    在执行插入操作时,如果插入的数据已存在主键冲突,就会导致插入操作失败,但是不会抛出异常。


    另外,在调用 mDb.rawQuery() 时,如果查询结果为空,也会返回 null。


    因此,在这种情况下,可能是因为插入的数据已存在主键冲突,导致插入操作失败,或者可能是因为调用 rawQuery() 查询结果为空。


    你可以尝试在插入数据之前,使用 SELECT 语句检查要插入的数据是否已存在,或者可以使用 INSERT OR IGNORE 语句,在插入数据时忽略主键冲突的情况。


    你也可以尝试在调用 rawQuery() 之后,使用 cursor.getCount() 方法来检查查询结果的行数,以确定是否有数据返回。


    此外,你也可以在调用 rawQuery() 方法之前,打印出 updateQuery 和 valVars 的值,以帮助你更好地了解问题所在。

    评论

报告相同问题?

悬赏问题

  • ¥50 导入文件到网吧的电脑并且在重启之后不会被恢复
  • ¥15 (希望可以解决问题)ma和mb文件无法正常打开,打开后是空白,但是有正常内存占用,但可以在打开Maya应用程序后打开场景ma和mb格式。
  • ¥20 ML307A在使用AT命令连接EMQX平台的MQTT时被拒绝
  • ¥20 腾讯企业邮箱邮件可以恢复么
  • ¥15 有人知道怎么将自己的迁移策略布到edgecloudsim上使用吗?
  • ¥15 错误 LNK2001 无法解析的外部符号
  • ¥50 安装pyaudiokits失败
  • ¥15 计组这些题应该咋做呀
  • ¥60 更换迈创SOL6M4AE卡的时候,驱动要重新装才能使用,怎么解决?
  • ¥15 让node服务器有自动加载文件的功能