gpt4 book ai didi

php - MySQL从同一个表中选择具有相同连接ID的多行

转载 作者:行者123 更新时间:2023-11-29 05:22:01 24 4
gpt4 key购买 nike

MySQL 数据库示例:

data_name | page_id | data
--------------------------
brand | 83 | brandA
brand | 88 | brandA
brand | 89 | brandA *
type | 89 | typeA *
type | 90 | typeA
type | 98 | typeA

我唯一要输入的数据是:

data_name = brand, 
data_name = type,
data = brandA,
data = typeA

我需要的是第一个相同的page_id。所以在这种情况下,89,89 是相同的。这就是我要返回的结果。

我所拥有的几乎可以工作的是:

 SELECT * FROM `data` WHERE (`data_name` = 'brand' AND `data` = 'brandA') OR (`data_name` = 'type' AND `data` = 'typeA')

我可以在 PHP 中获取结果,但我更愿意在 MySQL 中找出答案。

有什么想法吗?谢谢

最佳答案

只是猜测...

DROP TABLE IF EXISTS my_table;

CREATE TABLE my_table
(data_name VARCHAR(12) NOT NULL
,page_id INT NOT NULL
,data VARCHAR(12) NOT NULL
,PRIMARY KEY(data_name,page_id)
);

INSERT INTO my_table VALUES
('brand',83,'brandA'),
('brand',88,'brandA'),
('brand',89,'brandA'),
('type',89,'typeA'),
('type',90,'typeA'),
('type',98,'typeA');

SELECT x.page_id
FROM my_table x
WHERE (data_name,data) IN(('brand','brandA'),('type','typeA'))
GROUP
BY page_id
HAVING COUNT(*) = 2;
+---------+
| page_id |
+---------+
| 89 |
+---------+

关于php - MySQL从同一个表中选择具有相同连接ID的多行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24529735/

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