YashanDB 知识库|JDBC 查 st_geometry 报内存分配失败?一行授权搞定!

【问题描述】

某客户在通过 YashanDB JDBC 查询包含 st_geometry 字段的数据表时,出现如下异常:

YAS-00101: cannot allocate 0 bytes for anlHeapMalloc

此错误导致业务系统无法正常获取地理信息数据,查询直接失败。

【影响范围】

所有 YashanDB 版本

查询包含 st_geometry 类型字段的 SQL

使用 JDBC 驱动(不限版本)

【问题分析】

该异常源于:

当前数据库用户没有 st_geometry 类型的执行权限(EXECUTE ANY TYPE),导致驱动在反序列化该类型时内存分配失败。

st_geometry 是一种用户自定义类型(UDT),若没有执行权限,系统在尝试构造对象结构时会出错,从而触发 0 bytes 分配失败异常。

【解决方法】

为当前数据库用户添加 EXECUTE ANY TYPE 权限:

GRANT EXECUTE ANY TYPE TO ;

执行后即刻生效,无需重启服务。

【典型场景】

【规避建议】

【总结】

报错 YAS-00101 cannot allocate 0 bytes 往往不是内存问题,而是权限缺失;

关键是给用户加上对 st_geometry 类型的 EXECUTE 权限;

推荐在涉及 GIS 数据使用场景中默认赋权。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值