1
V2XEX 2018 年 10 月 30 日 via Android
你打印 SQL 看看是不是程序执行了意料之外的语句
|
2
rb6221 2018 年 10 月 30 日 via Android
量上去了就慢
|
3
vjnjc 2018 年 10 月 30 日
自定义 sql 是指定 select 内容吗?
|
4
lihongjie0209 2018 年 10 月 30 日
感觉是配置出问题了, JPA 有很多配置项可以在特定的场景下用来优化
|
5
builder 2018 年 10 月 30 日
个人觉得多表操作查询还是用存储过程快,没有 DBA 就直接 MyBatis 自己写 SQL,表和表之前不要用什么主外键关联,很慢的,而且后期维护特别不方便,更不方便拓展,所以 JPA 只用来进行简单的单表操作吧,能够节省一部分开发时间,运行效率没多大差距
|
6
lsongiu 2018 年 10 月 30 日
简单的 sql 还好,还可以配合二级缓存查询缓存使用,复杂的 sql 速度就明显不行了
|
7
unifier 2018 年 10 月 30 日
jpa 是基于 hibernate 的吧,比 mybatis 慢是正常的
|
9
johnniang 2018 年 10 月 30 日 via Android
基本上都没有进行多表关联。而是拆分请求进行多表关联,或者使用自定义 sql。
|
11
neoblackcap 2018 年 10 月 30 日
@builder 外键不会特别地让查询变慢。外键带来的成本大概是使插入变慢,扩展性变差。
|
13
wjh466587224 2018 年 10 月 30 日
jpa 配合 mongo 吧,mongo 都是集成成一个 collection,都属于单表查询了
|
14
rykinia 2018 年 10 月 31 日
我在公司产品上用了 JPA,在简单的 CRUD 中,和 mybatis 不可能有可直接观察到的差距
我觉得你应该检查数据库的配置,以及主键、索引什么的 |
15
colincat 2018 年 10 月 31 日
JPA 我感觉就行,没必要 mybatis 了,都 8102 年了,还搞 mybatis 没啥意思,配置繁多,表又不能自动生成,大部分都是简单的 CURD,连表直接用 nativeQuery 就好了,不要搞什么外键,后期难拆
最重要的还是看项目规模,什么样类型的项目来选择,推荐 JPA,用的很爽,实在觉得慢可以加一层缓存。 |
17
nezhaxiaozi OP @colincat 我们公司自己封装了 MyBatis 和 JPA,搞得好复杂的==...
|
19
builder 2018 年 11 月 9 日
@neoblackcap 单独 sql 语句查询 外键没多大影响,但是一旦外键和 Hibernate JPA 结合 ,通过 java 调用,百分百慢
|