
目前我们项目中都是 Dao 层没有使用 MyBatis 的关联,是在 Service 层自己进行拼接,这样子若是有表关联的业务就进行多次数据库查询。
那你们的公司项目中会有用到 MyBatis 的关联的功能么?
开发效率或性能上,使用或不使用关联会有很大的区别么?
1 loveCoding 2019-05-20 17:06:16 +08:00 不用,DBA 禁止... |
2 beneo 2019-05-20 17:09:17 +08:00 大公司的时候 DBA 禁止,只能 Mybatis,小公司的时候外键用的飞起,hibernate 拯救了我 |
3 HonoSV 2019-05-20 17:10:31 +08:00 多次查数据库,不会有性能问题么 |
4 watzds 2019-05-20 17:19:42 +08:00 via Android 某些时候多次查询,还有利于数据库缓存 |
5 lihongjie0209 2019-05-20 17:22:15 +08:00 这样不挺好的吗? 会有什么问题? |
6 night98 2019-05-20 17:27:55 +08:00 建议查阅阿里 java 开发手册,不建议使用任何关联查询 |
7 qiyuey 2019-05-20 17:32:46 +08:00 这样的方式对缓存是十分友好的,缓存的性能很强,数据库通常是瓶颈 |
8 Jrue0011 2019-05-20 17:57:12 +08:00 via iPhone 说成关联查询好像容易让有的人认为是 sql 的 join 了,其实 association 和 collection 是延迟调用查询方法… |
10 beginor 2019-05-20 18:56:36 +08:00 via Android 我们用 hibernate,推荐使用关联映射, 做好了还是比较爽的 |
11 Takamine 2019-05-20 21:38:59 +08:00 表示要求拆分成多次查询,用 BO 和 VO 去做拼接:doge:。 |
12 loveCoding 2019-05-21 09:18:21 +08:00 via iPhone @HonoSV 那就避免多次查询,比如 list 转 map 给下层,或者用 guava cache 自动刷新 |