- 数据库事务是对一个数据库执行工作单元,是针对数据库的一组操作,它可以由一条或多条SQL语句组成
- 事务是以逻辑顺序完成的工作单位或序列,可以是由用户手动操作完成,也可以是由某种数据库程序自动完成。
- SQLite是遵守ACID的关系型数据库管理系统。
- Atomicity(原子性) Consisitency(一致性)Isolation(隔离性) Durability(持久性)
实例:
张三在银行准备取出1000元时,王五在银行准备存入1000到银行中。
PersonSQLiteOpenHelper helper=new PersonSQLiteOpenHelper(getApplication());
SQLiteDatabase db=helper.getWritableDatase();//获取数据库对象
db.beginTransaction();//开启数据库事务
try{
db.execSQL("update person set accunt=accunt-1000 where name=?",new Object[]{"张三"});
db.execSQL("update person set accunt=accunt+1000 where name=?",new Object[]{"王五"});
db.setTransactionSuccessful();//设置事务标志为成功,当事务结束时提交事务
}catch(Exception e){
Log.i("事务处理失败",e.toString());
}finally{
db.endTransaction();//关闭数据库事务,执行时会检查是否由成功标记,有则提交事务,没有会回滚数据
db.close();
}