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

2017-12-21 14:42:08 +08:00
 esolve

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

@Service
class ShopService{

    @Transactional
    public void doTransaction(int type){      
         List<Customer> 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 语句,一次性发给数据库去执行,让中间结果在数据库里,这样性能会有显著提升吗?

929 次点击
所在节点    问与答
0 条回复

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/416551

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX