目前我们项目中都是 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 1
大公司的时候 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 1
这样的方式对缓存是十分友好的,缓存的性能很强,数据库通常是瓶颈
|
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 1
我们用 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 自动刷新
|