我正在使用以下查询,它返回大量重复记录。
SELECT * FROM specimen, topography_index, morphology, functions
WHERE
SUBSTRING(specimen.topography_index, 2, 2) = topography_index.topography_index_code
AND
if(specimen.snop_axis = 'M', morphology.morphology_code = specimen.snop_code, functions.functions_code = specimen.snop_code)
AND
specimen.topography_index = '_ORGAN_'
ORDER BY
(specimen.room = 'f') DESC,specimen.snop_code返回的记录数目约为59 000条。然而,标本表只有469条记录。形态学和函数表每个都有大约2000条记录,而topography_index表有29条记录,因此我猜想结果被“topography_index”和“形态学”或“functions”表(29x 2000)中的记录数相乘,无论哪种表在if子句中没有联接。
应该如何编写查询,这样才不会发生这种情况?
注意,GROUP不是一个选项,因为查询非常慢,所有记录都要返回。
http://sqlfiddle.com/#!2/2bda8/1
这也许可以通过if子句中的子select语句来处理?
任何帮助都很感激!
发布于 2014-07-09 04:17:06
您可能需要检查DISTINCT关键字,以统一一个或多个列的结果。
发布于 2014-07-09 04:32:58
如果这不适用于您,请创建一个包含4-5记录的SQLFiddle,以便很容易地跟踪错误。
改变这个
SUBSTRING(specimen.topography_index, 2, 2) = topography_index.topography_index_code 至
specimen.topography_index = SUBSTRING(topography_index.topography_index_code, 2, 2)https://stackoverflow.com/questions/24645279
复制相似问题