首页 > 解决方案 > 如何在查询输出中添加一个字段(针对每个返回的记录),其中包含我的查询返回的总数或记录?

问题描述

我不太喜欢 SQL,并且在处理可以返回 0,1,>1 记录作为输出的 MySql 查询时遇到以下问题。

我必须添加一个包含总行数的字段(每行)。因此,例如,如果我的查询返回的总数或记录总数为 4,则record_number字段将在所有返回的行中包含此值。

这是我的查询:

SELECT
    LS.id                                                                           AS livestock_id,
    LS.parent_livestock_species_id                                                  AS parent_livestock_species_id,
    LS.livestock_species_name_en                                                    AS livestock_species_name_en,
    IFNULL(LSN.livestock_species_name, LS.livestock_species_name_en)                AS livestock_species_name,  
    LSN.description                                                                 AS description,
    LS.image_link                                                                   AS image_link,
    count(*)                                                                        AS record_number
FROM LivestockSpecies                                                               AS LS
LEFT JOIN LivestockSpeciesName                                                      AS LSN
      ON LSN.livestock_species_id = LS.id AND LSN.language_id = 1
WHERE
    LS.id = 1
OR
    LS.parent_livestock_species_id = 1

以这种方式做我得到这个错误信息:

#42000In aggregated query without GROUP BY, expression #1 of SELECT list contains nonaggregated column 'digital_services_DB.LS.id'; this is incompatible with sql_mode=only_full_group_by

为什么?我该如何解决?

标签: mysqlsqldatabasegroup-byrdbms

解决方案


我猜语言表不会改变行数(这是合理的,因为left join),所以你可以在fromor中添加一个子查询select

select . . .
       (select count(*) from LivestockSpecies ls2 where ls2.id = 1 or ls2.parent_livestock_species_id = 1
       ) as total_number

在 MySQL 8.0 中,您可以使用窗口函数,因此更恰当地计算为:

select . . .
       count(*) over () as total_number

推荐阅读