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、永久解决方案

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

相关推荐
GIS数据转换器1 天前
无人机车载巡检系统
大数据·数据库·人工智能·数据挖掘·数据分析·无人机
AOwhisky1 天前
MySQL 学习笔记(第四期):SQL 语言之多表查询
linux·运维·网络·数据库·笔记·学习·mysql
小红卒1 天前
mysql之udf提权
数据库·mysql·网络安全
Trouvaille ~1 天前
【Redis篇】Redis 哨兵(Sentinel):高可用自动故障转移
数据库·redis·缓存·中间件·sentinel·高可用·哨兵
qfljg1 天前
oracle 迁移到postgres
数据库·oracle
六月雨滴1 天前
Oracle SGA 优化
oracle·dba
rockey6271 天前
基于AScript的SQL脚本语言发布啦!
sql·c#·.net·script·expression·动态脚本
giaz14n9X1 天前
Redis 分布式锁进阶第五十七篇
数据库·redis·分布式
剑神一笑1 天前
Linux ls 命令深度解析:从目录遍历到颜色输出的实现原理
linux·服务器·数据库
Maynor9961 天前
Codex API 网关迁移与流量优化实战
数据库·oracle