我有一个属性数据库。每个属性值都存储在一个表中,并带有其父属性的 ID。
在独立表中,我会编写一条 SQL 语句来提取数据
WHERE username = '' AND domain = ''
在属性表中,由于每个值都存储为单独的行,所以我不能这样做。我有一个联接,允许我带回一个值+结果(见下文),但是我需要一个基于 2 个标准的结果如上所示..
SELECT upa.value, up.status, u.status
FROM user_product up, product_attribute pa, product p, user u, user_product_attribute upa
WHERE pa.attribute_name = 'username'
AND pa.product_attribute_id = upa.product_attribute_id
AND pa.product_id = p.product_id
AND u.user_id = up.user_id
AND up.user_product_id = upa.user_product_id
AND p.product_name = 'email'
AND upa.value = 'exampleuser'
我想我需要再次加入上述的某种联盟?任何输入都会有帮助..
Thanks
请不要使用隐式连接语法。需要第二组连接才能获取第二个属性。
SELECT upa1.value, upa2.value, up1.status, u1.status
FROM product p
/* These joins get attribute/value for 'username' attribute */
INNER JOIN product_attribute pa1
ON p.product_id = pa1.product_id
AND pa1.attribute_name = 'username'
INNER JOIN user_product_attribute upa1
ON pa1.product_attribute_id = upa1.product_attribute_id
INNER JOIN user_product up1
ON upa1.user_product_id = up1.user_product_id
INNER JOIN user u1
ON up1.user_id = u1.user_id
/* These joins get attribute/value for 'domain' attribute */
INNER JOIN user_product_attribute upa2
ON upa1.user_product_id = upa2.user_product_id
INNER JOIN product_attribute pa2
ON upa2.product_attribute_id = pa2.product_attribute_id
AND pa2.attribute_name = 'domain'
WHERE p.product_name = 'email'
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)