mysql 存储过程,以及mybatis如何调用
2017-04-20 00:00
453 查看
说道存储过程,很多人都知道,但是真正用的人其实很少,但是在某些必要的场景,是必须使用的,虽然可以使用java代码解决,但是效率性能远不及存储过程
曾经在sqlserver 以及pgadmin上用过,mysql还真没使用过,今天遇到这样的场景那就使用一次吧
场景:订单自动失效,定时任务跑批的时候会查询出失效的订单,根据失效的订单中的相关item的id,再做相应的处理
mybatis调用:
service调用:
tips:同样的结果不同的手段,使用更优的手段来解决问题,几年前我会选择方便自己的做法,而现在要更多的考虑项目。
曾经在sqlserver 以及pgadmin上用过,mysql还真没使用过,今天遇到这样的场景那就使用一次吧
场景:订单自动失效,定时任务跑批的时候会查询出失效的订单,根据失效的订单中的相关item的id,再做相应的处理
begin declare cargoSourceId varchar(20); declare done int; declare cur_test CURSOR for select cargo_source_id from orders where order_status = '10' and datediff(NOW(),update_time)>=3; declare continue handler FOR SQLSTATE '02000' SET done = 1; open cur_test; repeat fetch cur_test into cargoSourceId; # 将要取消的失效对于的货源全部更新为“未下单”状态 update cargo_source set is_ordered=0,update_time=now() where id=cargoSourceId; until done end repeat; close cur_test; # 失效订单 update orders set order_status='50', update_time=now() where order_status = '10' and datediff(NOW(),update_time)>=3; end
mybatis调用:
<!-- 调用存储过程 --> <update id="updateOrderInvalidAfter3Days" statementType="CALLABLE"> CALL updateOrderInvalidAfter3Days </update>
service调用:
@Autowired private OrdersMapper ordersMapper; @Override public void updateOrderInvalidAfter3Days() { int result = ordersMapper.updateOrderInvalidAfter3Days(); System.out.println(result); }
tips:同样的结果不同的手段,使用更优的手段来解决问题,几年前我会选择方便自己的做法,而现在要更多的考虑项目。
相关文章推荐
- mysql 存储过程,以及mybatis如何调用
- MySQL 存储过程实例 与 ibatis/mybatis/hibernate/jdbc 如何调用存储过程
- iBatis调用存储过程以及MySQL创建存储过程
- iBatis调用存储过程以及MySQL创建存储过程
- Mybatis调用Mysql存储过程
- MySQL实现序列(Sequence)效果以及在Mybatis中如何使用这种策略
- myBatis配置文件中调用存储过程以及批量操作
- MYSQL 定时器调用存储过程 以及开启事件
- 如何使用mybatis调用存储过程
- mysql中的存储过程、触发器、视图是如何创建的,以及PHP中是如何调用的
- MySQL 存储过程带in和out参数以及PHP,PB如何调用的小例子
- MySQL 存储过程带in和out参数以及PHP,PB如何调用的小例子
- java-oop 连接sql数据库的方法和如何调用存储过程以及jdbc事物
- mybatis 调用存储过程,如何抛出sql异常
- myBatis调用带返回值的存储过程(mysql)
- Mybatis调用mysql存储过程
- mybatis调用mysql存储过程
- MyBatis—调用mysql存储过程 带输出输入参数
- mysql中的存储过程、触发器、视图是如何创建的,以及PHP中是如何调用的
- Mysql的存储过程,Mybatis对存储过程的调用