gpt4 book ai didi

mysql - sql multiple where on join

转载 作者:可可西里 更新时间:2023-11-01 09:01:44 25 4
gpt4 key购买 nike

A 有一个名为 advert_property 的表

pic1

我有一个表advert,这并不重要,广告属性通过advert_property 表中的advert_id 列连接到广告。

我写了这个 SQL 请求:

SELECT * 
FROM `advert`
JOIN advert_property ON advert.id = advert_property.advert_id
WHERE (advert_property.property_id = 1
AND advert_property.property_value = "Манчего")
AND (advert_property.property_id = 2
AND advert_property.property_value = "козий")

我想要的是具有某些属性的广告,例如:我想要一个具有 property_id = 1 和 property_value = "Манчего"并且具有 property_id = 2 和 property_value = "козий"的 idvert。 SQL请求返回null,我应该如何更改我的SQL请求。谢谢!

最佳答案

假设我正确理解了您的问题,并且您想返回所有具有both 属性的广告,那么有几种方法使用多个 joinexistsingroup by...

下面是使用多个连接的方法:

SELECT a.* 
FROM `advert` a
JOIN advert_property ap ON a.id=ap.advert_id
AND ap.property_id = 1 AND ap.property_value = 'Манчего'
JOIN advert_property ap2 ON a.id=ap2.advert_id
AND ap2.property_id = 2 AND ap2.property_value = 'козий'

关于mysql - sql multiple where on join,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39233386/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com