ormlite使用注意事项

本文探讨了在使用ORMLite Android进行大量数据插入时遇到的常见问题:由于数据库尚未完全创建即尝试插入数据而导致的失败。作者提出了一种解决方案:预先插入一条空白记录以确保数据库及表完全创建完毕后再进行后续数据的批量插入。

  本人在使用:

   compile 'com.j256.ormlite:ormlite-android:5.0'

 compile 'com.j256.ormlite:ormlite-core:5.0'
   经常会遇到这个依赖插入数据失败问题.
   
excelDaoOpe = excelSqliteOpenHelper.getDao(ExcelBean.class);
/**
 * 添加一个用户
 *
 * @param excelBean
 */
public void add(ExcelBean excelBean) {
    try {
        int id = excelDaoOpe.create(excelBean);
    } catch (SQLException e) {//这里经常插入失败
        logger.error("插入异常======e==="+e);
        e.printStackTrace();
    }
}
 
excelDaoOpe.create(excelBean); 这句代码在插入很多数据的时候,经常报错,,插入失败
  后来分析原因,这个代码
     excelDaoOpe.create(excelBean);在插入第一条数据的时候,才开始创建一个数据库,但是创建数据库和里面的表格是需要时间的
当插入很多数据时,当添加第一个bean的时候,紧接着有添加很多数据进去,会造成数据库还没有创建完成,就开始传入数据,导致插入失败的问题
 我的解决办法,是先添加一条空的bean进去(注意不能马上把这个插入的数据删除,否则,这个数据库又没有了,当只有一条数据的时候,如果删除掉这个数据,则这个数据库也会跟着被删除掉 ),
这样给它留一些时间,创建数据库和生成相应的表,后面在添加完这这些数据后,再删除掉之前添加的空的数据,既可,我采用这样的方式
数据库插入数据的时候,就不会出现插入失败的问题,这是我的解决方式!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值