首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >MySQL -返回的查询乘积记录-笛卡尔积

MySQL -返回的查询乘积记录-笛卡尔积
EN

Stack Overflow用户
提问于 2014-07-09 04:11:37
回答 2查看 83关注 0票数 0

我正在使用以下查询,它返回大量重复记录。

代码语言:javascript
复制
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语句来处理?

任何帮助都很感激!

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-07-09 04:17:06

您可能需要检查DISTINCT关键字,以统一一个或多个列的结果。

票数 0
EN

Stack Overflow用户

发布于 2014-07-09 04:32:58

如果这不适用于您,请创建一个包含4-5记录的SQLFiddle,以便很容易地跟踪错误。

改变这个

代码语言:javascript
复制
SUBSTRING(specimen.topography_index, 2, 2) = topography_index.topography_index_code 

代码语言:javascript
复制
specimen.topography_index = SUBSTRING(topography_index.topography_index_code, 2, 2)
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/24645279

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档