为什么老外不愿意使用 MyBatis?

栏目: Java · 发布时间: 5年前

内容简介:昨天我在我在知乎看到了一张比较Hibernate和MyBatis使用情况的图,顺手发了条朋友圈:

为什么老外不愿意使用 MyBatis?

老外用MyBatis吗

昨天我在我在知乎看到了一张比较Hibernate和MyBatis使用情况的图,顺手发了条朋友圈:

为什么老外不愿意使用 MyBatis?

Hibernate vs MyBatis ,谁能告诉我什么样的国情导致了这么大的差异?

结果有人质疑,有人感叹。

我开始没有想到会有人质疑这个结果,在我的直觉里,确实国外使用MyBatis的人很少(在国外的网站上很少看到MyBatis的文章,但JPA/Hibernate的文章经常看到)。所以今天早上我用google的trends验证了一下,上面的以及下面的这些比较图,都可以访问 https://trends.google.com/trends/explore?q=%2Fm%2F04t80p,MyBatis 来看到。

从下面这个对比来看,MyBatis的关注主要集中在中日韩。

为什么老外不愿意使用 MyBatis?

从全球的的比例来看,是这样的:

为什么老外不愿意使用 MyBatis?

上面是基于google查询的数据计算出来的,如果基于youtube,那结果是这样的:

为什么老外不愿意使用 MyBatis?

从以上的结果来看,在国外,准确地说,在中日韩之外的大部分地区,JPA/Hibernate完胜MyBatis,但在国内却完全相反,But Why?

老外为什么不用MyBatis?

为什么会这样呢?我也不知道。一些朋友发表了自己的想法:

为什么老外不愿意使用 MyBatis?

回复基本上分两种:

  • 青年 程序员 都在质疑这个图的可信度

  • 中老年程序员都在感叹国外其实更注重开发效率和面向对象的分析和设计

有个朋友说的非常好:

窃以为,唯独神州大量使用Mybatis,主要看重它不强化业务建模地搞表。

造成的后果是,宁可自己写 SQL 也不意义花力气使用OOAD思维方式梳理业务并建模。

而hibernate是OOAD建模后的自然延伸

好吧,下面是我个人的观点:

  • 确实,和对OOAD的重视有关,我在做DDD战术落地的时候,用MyBatis非常蹩脚,用JPA/Hibernate会好很多。

  • JPA/Hibernate比较复杂,团队中要有人Hold住它,否则及其容易踩坑;另外,真要使用,建议使用它的一个功能子集,不要所有功能都用。也可以尝试使用更简单EBean ORM。

  • JPA/Hibernate对分库分表的支持有一下坑。虽然,使用Shareding-JDBC或MyCat等技术,可以不关心分库分表,但是,JPA/Hibernate在某些情况下(比如加载子集合的时候)可能会不带分区键。国外分库分表的少,国内几乎是标配。

  • 国内做互联网的 Java 程序很多都是拷贝阿里的,阿里一开始用例iBatis(日本韩国是怎么回事呢)。大量的老系统都是基于iBatis/MyBatis的,市场上对MyBatis熟悉的人才更多,招聘和培训更容易,有的青年程序员以为“MyBatis早已统一全球了”就是一个很好的证明。

还有别的原因吗?大家可以补充。

题图是今天早上开车上班等红绿灯时照的,感觉这些天天气不太冷了,看到月亮辣么园,才知道是腊月十六了,要过年了,写了一首小诗:

码中无昼夜

寒尽知年终

五更驱车马

灯月两不分

你能找到图中的月亮吗?提前祝大家新春快乐,诸事如意。

「小得」是把日常工作中、学习中一些小的技术收获记录下来,目标是写满900篇。这是第2篇。

为什么老外不愿意使用 MyBatis?

长按2秒,识别二维码,关注我


以上所述就是小编给大家介绍的《为什么老外不愿意使用 MyBatis?》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Java多线程编程实战指南(设计模式篇)

Java多线程编程实战指南(设计模式篇)

黄文海 / 电子工业出版社 / 2015-10 / 59.00

随着CPU 多核时代的到来,多线程编程在充分利用计算资源、提高软件服务质量方面扮演了越来越重要的角色。而 解决多线程编程中频繁出现的普遍问题可以借鉴设计模式所提供的现成解决方案。然而,多线程编程相关的设计模式书籍多采用C++作为描述语言,且书中所举的例子多与应用开发人员的实际工作相去甚远。《Java多线程编程实战指南(设计模式篇)》采用Java(JDK1.6)语言和UML 为描述语言,并结合作者多......一起来看看 《Java多线程编程实战指南(设计模式篇)》 这本书的介绍吧!

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具