为什么老外不愿意用 MyBatis?

作者:陈龙 & 三观成型没法改

本文选自知乎问答「为什么国内流行mybatis,国外反而多用hibernate?」

陈龙:(zhihu.com/people/chenlong7890)

Spring 团队的Josh Long自己在Twitter上做了一个调查。1625次投票,样本量不算大,但也能说明问题。和我答案最后的那些调查图表基本一致。

我们看一下Google Trends的数据:

搜索条件是这样的:

World Wide:

United States:

France:

India:

Canada:

China:

Japan:

其他英文技术网站上的多个统计:

再看看Stack Overflow上的问题数:

(含有hibernate的标签和问题数)

(含有mybatis的标签和问题数)

三观成型没法改:

(zhihu.com/question/309662829/answer/579433240)

这其实是一个很严重的错觉,首先,欧美的互联网企业程序员在激进程度上是不下于国内的,新技术、偏门技术的应用小范围的也不少。

其次,细分在java语言的系统集成和传统行业解决方案上,国外确实普遍在使用hibernate。

但我觉得这个选择本身是不掺杂技术优劣的,就好像因为马车的宽度,所以现在标准的宽轨铁路和马路汽车的宽度是xx一样,更多是因为惯性。

管理风格和思路的问题而已。

以我接触的某知名外企为例(top500),至今他们还有20年前的文档数据库在运行。

这种事情如果是在国内,早被干掉了,但是他们一直用到了现在。

我当时问他们的pm是什么原因才会使用这个系统,并且不升级。

人家说估计安全级别,这个系统是0级(最高级),但是使用频率和系统重要性都高于5,也就是一年用不了几回这种,安排开发预算整体升级几乎完全没有性价比,所以就pass了。

hibernate也是,可能hibernate确实已经不满足使用了,但是重构和升级的优先级不高,性价比不够,那么风控和预算上都不给过了,谁去改??

反过来讲,Facebook和tt还有谷歌这些,你听说过他们的什么java项目,或者更新分的hibernate项目么?

国内就是另一种风格了,我在几年前的回答里有过一次关于之前某个工作的吐槽,bd签了一个80万的合同,boss为了敏捷推进,中断产品线2个月紧急上线,前后投入研发成本300多万,最后以甲方的身份干了乙方的事,系统完全没有可复用性,这种傻缺事,在欧美公司能绕开风控和财务么。

这种拍脑门一句话绕开风控需求和财务的工作计划,在中日韩都是一脉相承的。(比如这次的拼多多,是他员工智商低么?这种体系上的缺陷一定是因为管理层人治大于制度啊。)

mybatis最大的一个特征就是,特别特别急的情况下可以拍脑门临时改,用一些所谓“临时解决方案”(懂的人都懂)。

hibernate如果没有总体设计的话,哪里有那么随便就能临时改动的(临时方案也可以用,但是没有那么方便)?

公司管理风格趋向于降低风险,和公司管理风格趋向于领导个人感受,导致了在管理、文化、制度上的全面差异,最终导致了技术选型的差异。

7