Java 程序员常犯的 10 个 SQL 错误!
时间:2021-08-19 15:18:11
[导读]作者| LianyouCQ,LeoXu,yale8848,开源中国驻联合国理事,super0555来源| https://www.oschina.net/translate/10-common-mistakes-java-developers-make-when-writing-...
作者 | LianyouCQ, LeoXu, yale8848, 开源中国驻联合国理事, super0555
来源 | https://www.oschina.net/translate/10-common-mistakes-java-developers-make-when-writing-sqlJava程序员编程时需要混合面向对象思维和一般命令式编程的方法,能否完美的将两者结合起来完全得依靠编程人员的水准:
5、在Java内存中加入数据从SQL的初期开始,当在SQL中使用JOIN语句时,一些开发者仍旧有不安的感觉。这是源自对加入JOIN后会变慢的固有恐惧。假如基于成本的 优化选择去实现嵌套循环,在创建一张连接表源前,可能加载所有的表在数据库内存中,这可能是真的。但是这事发生的概率太低了。通过合适的预测,约束和索 引,合并连接和哈希连接的操作都是相当的快。这完全是是关于正确元数据(在这里我不能够引用Tom Kyte的太多)。而且,可能仍然有不少的Java开发人员加载两张表通过分开查询到一个映射中,并且在某种程度上把他们加到了内存当中。解决方法:假如你在各个步骤中有从各种表的查询操作,好好想想是否可以表达你的查询操作在单条语句中。6、在一个临时的笛卡尔积集合中使用 DISTINCT 或 UNION 消除重复项通过复杂的连接,人们可能会对SQL语句中扮演关键角色的所有关系失去概念。特别的,如果这涉及到多列外键关系的话,很有可能会忘记在JOIN .. ON子句中增加相关的判断。这会导致重复的记录,但或许只是在特殊的情况下。有些开发者因此可能选择DISTINCT来消除这些重复记录。从三个方面来说 这是错误的:
来源 | https://www.oschina.net/translate/10-common-mistakes-java-developers-make-when-writing-sqlJava程序员编程时需要混合面向对象思维和一般命令式编程的方法,能否完美的将两者结合起来完全得依靠编程人员的水准:
- 技能(任何人都能容易学会命令式编程)
- 模式(有些人用“模式-模式”,举个例子,模式可以应用到任何地方,而且都可以归为某一类模式)
- 心境(首先,要写个好的面向对象程序是比命令式程序难的多,你得花费一些功夫)
- 好好的训练你自己。当你写SQL时要不停得想到NULL的用法:
- 这个NULL完整性约束条件是正确的?
- NULL是否影响到结果?
- 便利性。这比在Java中编写正确的SQL可能更加的容易。
- 性能表现。数据库应该比你的算法处理起来更加快.而且更加重要的是,你不必再去传递数百万条记录了。
- UNION ALL(允许重复)
- UNION (去除了重复)
5、在Java内存中加入数据从SQL的初期开始,当在SQL中使用JOIN语句时,一些开发者仍旧有不安的感觉。这是源自对加入JOIN后会变慢的固有恐惧。假如基于成本的 优化选择去实现嵌套循环,在创建一张连接表源前,可能加载所有的表在数据库内存中,这可能是真的。但是这事发生的概率太低了。通过合适的预测,约束和索 引,合并连接和哈希连接的操作都是相当的快。这完全是是关于正确元数据(在这里我不能够引用Tom Kyte的太多)。而且,可能仍然有不少的Java开发人员加载两张表通过分开查询到一个映射中,并且在某种程度上把他们加到了内存当中。解决方法:假如你在各个步骤中有从各种表的查询操作,好好想想是否可以表达你的查询操作在单条语句中。6、在一个临时的笛卡尔积集合中使用 DISTINCT 或 UNION 消除重复项通过复杂的连接,人们可能会对SQL语句中扮演关键角色的所有关系失去概念。特别的,如果这涉及到多列外键关系的话,很有可能会忘记在JOIN .. ON子句中增加相关的判断。这会导致重复的记录,但或许只是在特殊的情况下。有些开发者因此可能选择DISTINCT来消除这些重复记录。从三个方面来说 这是错误的:
- 它(也许)解决了表面症状但并没有解决问题。它也有可能无法解决极端情况下的症状。
- 对具有很多列的庞大的结果集合来说它很慢。DISTINCT要执行ORDER BY操作来消除重复。
- 对庞大的笛卡尔积集合来说它很慢,还是需要加载很多的数据到内存中。
- 使SQL更易读(但在子查询中没有GROUP BY语句专业)
- 提升性能,像关系数据库管理系统能够更容易优化窗口函数
- SQL排序很慢
- SQL排序办不到





