我有两个表分别命名为“数据”和“区域”。我想获取具有数据相关记录的区域作为区域记录的项目。

地区

RegionId -- Name -- ParentId

数据
DataId -- RegiondId -- Url

样本结果:
[
{Name:"a", items:[{...},{...},{...}, ...]},
{Name:"b", items:[{...},{...},{...}, ...]},
]

我用这个查询
SELECT *,(
    SELECT *
    FROM data
    WHERE data.RegionId=regions.RegionId
) AS items
FROM regions
WHERE regions.ParentId=1

但是我得到了SQLSTATE[21000]: Cardinality violation: 1241 Operand should contain 1 column(s)

重要提示:地区在其记录之间具有父级关系。因此,当我编写此条件data.RegionId=regions.Id时,它必须返回与子项的RegionIds相匹配的项。

最佳答案

选择列表中的子查询必须返回一列和一行(单个值),但是那里有一个select *,因此会出现错误消息。

您的查询应编写为简单的内部联接,而不是子查询:

SELECT *
FROM regions
INNER JOIN data ON data.RegionId=regions.RegionId
WHERE regions.ParentId=1

关于php - SQLSTATE [21000] : Cardinality violation: 1241 Operand should contain 1 column(s). sql查询,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/38326246/

10-09 16:50