weixin_41070914
小浩MR.C
采纳率100%
2020-07-03 11:42

spring boot环境,在service里调用线程,线程执行一条sql插入语句,执行Test测试无报错,但数据库没数据

已采纳
  • service层代码
UserService service;

@Autowired
public void setService(UserService service) {
       this.service = service;
 }

@Override
public void add(User user) {
        System.out.println(mapper);
        Thread thread = new Thread(new MyRunnable(mapper, user));
        thread.start();
    }


class MyRunnable implements Runnable {

    UserMapper mapper;
    User user;

    public MyRunnable(UserMapper mapper, User user) {
        this.mapper = mapper;
        this.user = user;
        System.out.println(mapper);
        System.out.println(user);
    }

    @Override
    public void run() {
        mapper.insert(user);
    }
}

@Test
public void test1() {
        User u1 = new User(1L,"A");
        service.add(u1);
}

控制台输出

输出代码

数据库确没数据,又不报错。

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 复制链接分享
  • 邀请回答

2条回答

  • marty535 marty535 9月前

    程序结束的太早了,数据库插入式需要时间的,不信你最后sleep下

    点赞 1 评论 复制链接分享
  • monkeycoding monkeycoding 9月前

    Junit进行测试时默认是开启事务回滚的(防止写入测试数据)
    因此查询语句正常运行,更新语句虽然运行正常但是最后不会向数据库写数据
    如果确实有必要写入数据,可以手动关闭事务回滚
    在test方法上添加@Rollback(false)就可以了

    点赞 评论 复制链接分享