HGDB 4.5.8.8开启oracle兼容执行带聚合函数的SQL导致数据库进程被信号11杀死

文章目录

环境

系统平台:银河麒麟 (海光)

版本:4.5.8

症状

数据库版本:瀚高安全版4.5.8.8

介质包:hgdb-see-4.5.8.8-3937-efc2bbd-20241016.x86_64.rpm

信号11的报错信息:

2025-06-16 10:23:04.890 CST,1857,681b3d37.741,370,2025-05-07 19:00:07 CST,0,LOG,00000,"server process (PID 656071) was terminated by signal 11: Segmentation fault","Failed process was running:xxx查询SQL

报错SQL:

sql 复制代码
1)非聚合字段不在group by中的SQL
SELECT t1.id
	,t1.v
	,t1.v1
	,count(t1.id) AS num
FROM t1
LEFT JOIN t2 ON t1.id = t2.id
WHERE t1.v1 IS NOT NULL;
2)group by中包含所有非聚合字段,但是order by字段不在group by中的SQL
SELECT t1.id
	,t1.v
	,t1.v1
	,count(t1.id) AS num
FROM t1
LEFT JOIN t2 ON t1.id = t2.id
WHERE t1.v1 IS NOT NULL
GROUP BY t1.id
	,t1.v
	,t1.v1
ORDER BY t2.id;

问题原因

数据库开启oracle兼容后group by、order by相关语法与oracle仍有区别,使用oracle兼容的分支会引起信号11导致数据库服务异常。

解决方案

1、临时解决方案:

1)非聚合字段不在group by中的SQL,要把非聚合字段都添加到group by中。

修改后的SQL:

sql 复制代码
SELECT t1.id
	,t1.v
	,t1.v1
	,count(t1.id) AS num
FROM t1
LEFT JOIN t2 ON t1.id = t2.id
WHERE t1.v1 IS NOT NULL
GROUP BY t1.id
	,t1.v
	,t1.v1;

2)group by中包含所有非聚合字段,但是order by字段不在group by中的SQL,要把order by中不在group by中的字段删除,按需改成group by中的字段。

修改后的SQL:

sql 复制代码
SELECT t1.id
	,t1.v
	,t1.v1
	,count(t1.id) AS num
FROM t1
LEFT JOIN t2 ON t1.id = t2.id
WHERE t1.v1 IS NOT NULL
GROUP BY t1.id
	,t1.v
	,t1.v1
ORDER BY t1.id; --t2.id改成了t1.id

2、永久解决方案

申请补丁包或者升级数据库版本。

相关推荐
GBASE14 小时前
G术时刻 |GBase 8s数据库事务并发控制之封锁技术介绍(下)
数据库
xiezhr1 天前
逛GitHub发现了一款免费的带AI功能的数据库管理工具
数据库·ai编程·dba
唐青枫2 天前
MySQL JSON 实战详解:从存储、查询、更新到 JSON_TABLE 与索引
sql·mysql
吃糖的小孩2 天前
给 QQ AI 机器人设计“可控记忆”:会话摘要、手动长期记忆与角色卡边界
数据库
笃行3503 天前
金仓数据库数据安全双防线:静态存储加密与传输加密实战
数据库
笃行3503 天前
金仓数据库物理备份实战:sys_rman 全流程演练与误覆盖抢救
数据库
笃行3503 天前
金仓数据库逻辑备份实战:从全库导出到 Schema 替换的完整闭环
数据库
SelectDB4 天前
阶跃星辰基于 SelectDB 构建 PB 级 Agent 可观测平台
大数据·数据库·aigc
这个DBA有点耶4 天前
GROUP BY优化全解:如何写出既不丢数据又飞快的分组查询
数据库·mysql·架构