首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >MySQL if条件then左连接

MySQL if条件then左连接
EN

Stack Overflow用户
提问于 2014-04-01 15:55:11
回答 2查看 826关注 0票数 1

我在页面底部有一个有效的Select。正如您所看到的,它有53行,在我看来,这太多了。有人告诉我,在MySQL中有一个'if‘条件,但我不能让它工作。工作的选择联合4选择,因为在每个选择中,我需要连接另一个表。是否可以根据表的内容来连接表?

代码语言:javascript
复制
SELECT *
FROM (
    SELECT m.`identificator` , ml.id AS link_id, ml.parent, ml.type, 
            ml.destination, ml.disabled, ml.order, mld.`name` AS link_name, 
            mld.`alt` , mld.`title` , cpd.`slug` 
    FROM  `wf_menu` m
    LEFT JOIN  `wf_menu_link` ml ON m.`id` = ml.`menu_id` 
    LEFT JOIN  `wf_menu_link_desc` mld ON ml.`id` = mld.`link_id` 
    LEFT JOIN  `wf_cms_post_desc` cpd ON ml.destination = cpd.post_id
    WHERE mld.`lang_id` =1
    AND mld.`lang_id` = cpd.`lang_id` 
    AND (ml.`type` =  'page'
    OR ml.`type` =  'article')

    UNION

    SELECT m.`identificator` , ml.id AS link_id, ml.parent, ml.type, 
            ml.destination, ml.disabled, ml.order, mld.`name` AS link_name, 
            mld.`alt` , mld.`title` , cpd.`slug` 
    FROM  `wf_menu` m
    LEFT JOIN  `wf_menu_link` ml ON m.`id` = ml.`menu_id` 
    LEFT JOIN  `wf_menu_link_desc` mld ON ml.`id` = mld.`link_id` 
    LEFT JOIN  `wf_cms_category_desc` cpd ON ml.destination = cpd.category_id
    WHERE mld.`lang_id` =1
    AND mld.`lang_id` = cpd.`lang_id` 
    AND ml.`type` =  'cmscat'

    UNION

    SELECT m.`identificator` , ml.id AS link_id, ml.parent, ml.type, 
            ml.destination, ml.disabled, ml.order, mld.`name` AS link_name, 
            mld.`alt` , mld.`title` , spd.`slug` 
    FROM  `wf_menu` m
    LEFT JOIN  `wf_menu_link` ml ON m.`id` = ml.`menu_id` 
    LEFT JOIN  `wf_menu_link_desc` mld ON ml.`id` = mld.`link_id` 
    LEFT JOIN  `wf_shop_category_desc` spd ON ml.destination = spd.category_id
    WHERE mld.`lang_id` =1
    AND mld.`lang_id` = spd.`lang_id` 
    AND ml.`type` =  'shopcat'

    UNION

    SELECT m.`identificator` , ml.id AS link_id, ml.parent, ml.type, 
            ml.destination, ml.disabled, ml.order, mld.`name` AS link_name, 
            mld.`alt` , mld.`title` , 'link' as slug 
    FROM  `wf_menu` m
    LEFT JOIN  `wf_menu_link` ml ON m.`id` = ml.`menu_id` 
    LEFT JOIN  `wf_menu_link_desc` mld ON ml.`id` = mld.`link_id` 
    WHERE mld.`lang_id` =1
    AND ml.`type` =  'link'

) a
ORDER BY `order` DESC
EN

回答 2

Stack Overflow用户

发布于 2014-04-01 16:19:26

我认为您需要使用动态SQL。我的意思是,将end SQL构建到一个临时变量中并执行它:

代码语言:javascript
复制
set @query = (SELECT ...);
PREPARE st FROM @query;
EXECUTE st;

你的第一个案例可能是这样的:

代码语言:javascript
复制
SET @query= (SELECT CONCAT(GROUP_CONCAT(CONCAT('SELECT m.`identificator` , ml.id AS link_id, ml.parent, ml.type, 
            ml.destination, ml.disabled, ml.order, mld.`name` AS link_name, 
            mld.`alt` , mld.`title` , cpd.`slug` FROM  `wf_menu` m LEFT JOIN  `wf_menu_link` ml ON m.`id` = ml.`menu_id` ',
            CASE WHEN TTYPES.type='article' THEN 
                CONCAT('LEFT JOIN  `wf_menu_link_desc` mld ON ml.`id` = mld.`link_id` LEFT JOIN  `wf_cms_post_desc` cpd ON ml.destination = cpd.post_id WHERE mld.`lang_id` =1 AND mld.`lang_id` = cpd.`lang_id` AND (ml.`type` =  \'page\' OR ml.`type` =  \'',TTYPES.type,'\')')

            END )
SEPARATOR ' UNION '), ' SELECT NULL FROM wf_menu_link WHERE 1=2') FROM (SELECT DISTINCT wf_menu_link.`type` FROM wf_menu_link) TTYPES);

(你可以完成剩下的案例)

运行该查询将使用生成的查询填充@query变量。生成的查询应该与您在问题中发布的查询相同。然后你可以运行它,就像你在上面的答案中看到的那样。

这是一个例子/想法,你必须完成它和/或检查它在你的模型中是否有效。

票数 0
EN

Stack Overflow用户

发布于 2014-04-01 16:50:28

您可以只执行一个查询,其中包含每个左连接,然后使用if语句对得到的'slug‘列进行排序。但是,这取决于您想要输出什么,以及其他表上是否有多个匹配的行。

就像这样:

代码语言:javascript
复制
SELECT m.identificator , ml.id AS link_id, ml.parent, ml.type, 
        ml.destination, ml.disabled, ml.order, mld.name AS link_name, 
        mld.alt , mld.title , cpd.slug 
FROM  wf_menu m
LEFT JOIN  wf_menu_link ml ON m.id = ml.menu_id 
LEFT JOIN  wf_menu_link_desc mld ON ml.id = mld.link_id 
LEFT JOIN  wf_cms_post_desc cpd ON ml.destination = cpd.post_id AND (ml.type = 'page' OR ml.type = 'article')
LEFT JOIN  wf_cms_category_desc cpd ON ml.destination = cpd.category_id AND ml.type =  'cmscat' AND mld.lang_id = cpd.lang_id 
LEFT JOIN  wf_shop_category_desc spd ON ml.destination = spd.category_id AND ml.type =  'shopcat' AND mld.lang_id = spd.lang_id 
WHERE mld.lang_id =1
AND mld.lang_id = cpd.lang_id 
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/22779866

复制
相关文章

相似问题

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