Java /mybatis/hibernate 将多条 mysql 语句放在一个 Dao 函数里会提升性能吗?

0 0 java mybatis
星夜小筑
星夜小筑

声望值:155 0人

2018-12-20 09:58:20 提问

关注 0关注

收藏 0收藏, 15浏览

譬如 java 里的一个 service,里面有事务

@Service
class ShopService{

@Transactional
public void doTransaction(int type){      
     List customerList = customerDao.getByType(type);
     couponDao.assign(customerList);    
}

}

我的理解是:

1 java 程序将 customerDao.getByType(type);对应的 mysql 语句通过数据库连接发给数据库

2 数据库产生结果,将 customerList 发给 java 程序

3 java 程序将 couponDao.assign(customerList);对应的 mysql 语句通过数据库连接发给数据库

4 数据库产生结果,将结果发给 java 程序

这样,如果中间结果 customerList 很大的话,网络传输性能损耗比较大

假如如下做法:

@Service
class ShopService{

@Transactional
public void doTransaction(int type){      
     couponDao.assignCustomersByType(type);    
}

}

couponDao.assignCustomersByType(type); 对应两条 mysql 语句,一次性发给数据库去执行,让中间结果在数据库里,这样性能会有显著提升吗?

请先 登录 后评论

2个回答

  • RAID丶小筑232声望 2018-10-15 15:56

    很多优化都是没有必要的, 启用数据库端的慢sql日志,仅需优化真正慢的,其他的不要猜,拿数据说话
    请先 登录 后评论
  • 闭麦听歌1v9118声望 2018-10-15 15:56

    你都不发sql 说屁
    请先 登录 后评论

注册新账号

悬赏追问
10
  • 10
  • 20
  • 50
  • 100
  • 200
  • 输入数值
发布追问