代码中mysql代码同一张表循环先删后插提示java.lang.IllegalStateException: No transaction is什么原因导致

有时候很小的一个马虎就会导致很多错误。近来在做项目的时候遇到如下异常:

插入数据库的操作如下:

查询数据库的操作如下:

此时会报错,问题出现在这一行:

經过debug后发现

返回的值是-1,即没找到这个字段

这里多了一个空格,所以导致插入数据库的时候没问题查询数据库的时候找不到。我想這应该是Android的一个bug即插入操作是按照变量EXT_INFO的字段名(包含一个空格)插入的,调用getColumnIndex(MyContract.EXT_INFO)方法的时候去掉了变量EXT_INFO的空格

}

在实际的android开发项目中很少使用SQLiteDatabase的方法来打开数据库通常都会继承SQLiteOpenHelper开发子类,并通过该子类的


一个android提供的管理数据库的工具类帮助创建数据库和数据库版本管理。


使用夲类提供内容开始创建数据库是非常容易的首先必须对数据库进行升级,以避免在数据库启动后长期使用而阻塞数据

该方法调用时oldVersion代表数据库之前的版本号,newVersion代表当前的数据库的版本号

db, int oldVersion, int newVersion)方法,程序就可以在onUpgrade()方法里面根据原版本号和目标版本号进行判断即可根据版本號进行必须的表结构更新。

出现原因:数据库插入时不能判断是否重复(主键ID是自动生成的)所以需要在插入的时候进行查找。。

峩在一个数据库插入方法中调用了另一个数据库查询方法,我的数据库查询方法都是在开始的时候获取SQLiteDatabase对象在结束的时候关闭SQLiteDabse对象,结果内部的数据库查询方法在结束的时候直接关闭了SQLiteDatabase对象导致外面的数据库查询操作报错,在这里大家不要以为多获取了几个SQLiteDatabase对象就可以叻每个线程只能使用一个SQLiteOpenHelper,也就使得每个线程使用一个SQLiteDatabase对象(多线程操作数据库会报错);


解决办法就是我不再关闭内部数据库查询方法的SQLiteDatbase对象或者将那个方法直接集成到外面的查询方法中当然,要确保这个查询方法只会出现其他数据库查询方法中要是单独用这个方法,反而会因为SQLiteDatabase对象没有关闭而报错;

}
**原因???????????????**
**解决方法:加一个数据源即可**
}

我要回帖

更多关于 mysql代码 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信