小小少年QAQ 2023-05-17 16:53 采纳率: 30%
浏览 12

mysql迁移金仓数据库中分组的问题


 select afai.districtcode code,
        count(afai.alarm_type = '2' or null ) forest_alarm,
        count(afai.alarm_type = '1' or null ) non_forest_alarm,
        count(afai.fire_type = '2' or null ) forest_fire,
        count(afai.fire_type = '1' or null ) non_forest_fire,
        afai.source_name district
        from enbogis.bis_all_fire_alarm_index afai
        WHERE 1=1
        and source_lon is not null and source_lat is not null and fire_lon is not null and fire_lat is not NULL
        group by afai.districtcode
        having forest_fire>0 or non_forest_fire>0 or forest_alarm>0 or non_forest_alarm>0

错误信息 
SQL 错误 [42803]: 错误: 字段 "afai.source_name" 必须出现在 GROUP BY 子句中或者在聚合函数中使用
  Position: 285 At Line: 6, Line Position: 9

之前从mysql迁移到金仓数据库,数据迁移完成后,该后端的代码,就出现上面的错误按照提示修改过后确发现与原sql查询出来的数据不一样
修改过后的金仓sql多了很多条数据 不知道怎么办才好 希望各位帮帮我 钛痛苦了!!

  • 写回答

2条回答 默认 最新

  • 「已注销」 2023-05-17 17:15
    关注

    参考GPT和自己的思路:根据错误信息提示,需要将字段 "afai.source_name" 放入 GROUP BY 子句中或者在聚合函数中使用,根据你提供的代码,需要将 afai.source_name 放入 GROUP BY 子句中,即将 "group by afai.districtcode" 修改为 "group by afai.districtcode, afai.source_name"。这样可以解决错误信息提示的问题。

    至于数据量变化的问题,可能是迁移后金仓数据库中的数据不同于 MySQL 数据库中的数据,或者代码修改后查询条件有所改变,导致查询结果不同,需要进一步检查。建议对比 MySQL 数据库和金仓数据库中的数据,以及对比修改前后的代码和查询结果进行排查。

    评论

报告相同问题?

问题事件

  • 创建了问题 5月17日

悬赏问题

  • ¥30 STM32 INMP441无法读取数据
  • ¥100 求汇川机器人IRCB300控制器和示教器同版本升级固件文件升级包
  • ¥15 用visualstudio2022创建vue项目后无法启动
  • ¥15 x趋于0时tanx-sinx极限可以拆开算吗
  • ¥500 把面具戴到人脸上,请大家贡献智慧
  • ¥15 任意一个散点图自己下载其js脚本文件并做成独立的案例页面,不要作在线的,要离线状态。
  • ¥15 各位 帮我看看如何写代码,打出来的图形要和如下图呈现的一样,急
  • ¥30 c#打开word开启修订并实时显示批注
  • ¥15 如何解决ldsc的这条报错/index error
  • ¥15 VS2022+WDK驱动开发环境