为什么国内流行的 MyBatis ,国外 Java 工程师却不愿意使用?

共 1226字,需浏览 3分钟

 ·

2021-12-14 18:43

关注不迷路

来源:zhihu.com/question/309662829
Spring 团队的Josh Long自己在Twitter上做了一个调查。1625次投票,样本量不算大,但也能说明问题。和我答案最后的那些调查图表基本一致。
图片
我们看一下Google Trends的数据:
搜索条件是这样的:
图片
World Wide:
图片
United States:
图片
France:
图片
India:
图片
Canada:
图片
China:
图片
Japan:
图片
其他英文技术网站上的多个统计:
图片
图片
再看看Stack Overflow上的问题数 :
图片
(含有hibernate的标签和问题数)
图片
(含有mybatis的标签和问题数)
下面是我个人的观点:
其实十年前我们主要使用的ORM框架就是iBatis,而阿里巴巴是对国内Java开发者影响最大的一家公司。阿里在国内Java社区的影响力有目共睹,这个大家应该都能感受到, 阿里对Java社区贡献了很多实用的开源工具,并且国内Java开发者对于阿里开源的产品接纳程度也最高。
而且早期阿里系离职工程师的影响力也不可小觑,这些从阿里离职的工程师进入了各个规模的公司, 通常也有担任较高的职位, 拥有着相对较多的话语权, 在新公司继续使用自己熟悉的iBatis就是再正常不过的了。
MyBatis封装较少,提供的切入点较多,适合进行架构。遇到超级复杂的场景的时候有不错的sql支持。曾经JPA适合做增删改,mybatis只擅长查询,但是现在的tk.mybatis已经补上了这一块短板,而JPA的依然没有补上他的查询短板。在复杂情况下需要在代码里嵌入大量sql片段或手动用代码拼装sql,但是老实说,都到这份上了,写sql不是还更快一点?因此,做企业级应用时,如果组内Hibernate会的人多,可以考虑用这个,但是依然会埋下一个性能的坑。做互联网级应用时,建议还是用Mybatis吧。
综合考虑,Mybatis的优点是简单高效,优化起来也方便,比较符合现在的开发节奏,现在的互联网公司都是先快速开发占领市场,然后再优化代码。而且这个过程需求经常是变来变去的,开发人员也有流动性,这种情况下用Mybatis显然更加适合。

逆锋起笔是一个专注于程序员圈子的技术平台,你可以收获最新技术动态最新内测资格BAT等大厂的经验精品学习资料职业路线副业思维,微信搜索逆锋起笔关注!

近期热文


微软正式发布 Windows 11 SE
重磅!网页版 VSCode 来了!
4 种主流的 API 架构风格对比
小技巧,IDEA 卡住不动解决办法
Win11 的这 19 个新功能,你都用上了吗?



好文章,我在看❤️
浏览 86
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报