本篇文章给大家分享的是有关weed3-5中怎么实现事务和事务队列,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。
//demo1:: //事务组 // 在一个事务里,做4个插入//如果出错了,自动回滚
DbUserApi dbUserApi = XmlSqlProxy.getSingleton(DbUserApi.class);
db.tran((t) -> {
//
// 此表达式内的操作,会自动加入事务
//
//sql接口
db.sql("insert into test(txt) values(?)", "cc").insert();
db.sql("update test set txt='1' where id=1").execute();
//call接口
db.call("user_del").set("_user_id",10).execute();
//table()接口
db.table("a_config").set("cfg_id",1).insert();
//xml mapper
dbUserApi.user_add(12);
//大家使用统一的事务模式
});
//demo2:: //事务队列
//
//假如,要跨两个数据库操作(一个事务对象没法用了)
//
DbContext db = DbConfig.pc_user;
DbContext db2 = DbConfig.pc_base;
//创建个事务队列(和传统概念的队列不一样)
DbTranQueue queue = new DbTranQueue();
//数据库1的事务
db.tran().join(queue).execute((t) => {
//
// 在这个表达示内,会自动加入事物
//
db.sql("insert into test(txt) values(?)", "cc").execute();
db.sql("insert into test(txt) values(?)", "dd").execute();
db.sql("insert into test(txt) values(?)", "ee").execute();
});
//数据库2的事务
db2.tran().join(queue).execute((t) => {
//
// 在这个表达示内,会自动加入事物
//
db2.sql("insert into test(txt) values(?)", "gg").execute();
});
//队列结组完成(即开始跑事务)
queue.complete();
public void test_main(){
DbTranQueue queue = new DbTranQueue();
test1(queue);
test2(queue);
}
public void test1(DbTranQueue queue){
DbTran tran = DbConfig.db1.tran();//生成个事务对象
tran.join(queue).execute((t) -> {
//
// 在这个表达示内,会自动加入事物
//
t.db().sql("insert into $.test(txt) values(?)", "cc").insert();
t.db().sql("insert into $.test(txt) values(?)", "dd").execute();
t.db().sql("insert into $.test(txt) values(?)", "ee").execute();
t.result = t.db().sql("select name from $.user_info where user_id=3").getValue("");
});
}
public void test2(DbTranQueue queue){
//...test2就不写了
}
以上就是weed3-5中怎么实现事务和事务队列,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注天达云行业资讯频道。