lightdb 普通用户拥有XMLTYPE类型的访问权限

文章目录

概述

在信创移植的SQL语句中,有来源于Oracle数据库的SQL语句。

在Oracle中存在getClobVal函数,这个函数是Oracle中sys.XMLType的成员方法。

因此在LightDB23.3版本中实现了TYPE支持定义成员方法并且在新定义的XMLType类型中实现getClobVal成员方法。

但是实际场景是普通用户需要默认有XMLType.getClobValue的执行权限,无需另外进行授权。对此 LightDB 23.3.02增量版本进行了支持。

示例

使用ltsql进行命令行

构建数据库

复制代码
create database test_oracle with lightdb_syntax_compatible_type  oracle;
\c test_oracle
select dbms_output.serveroutput(true);

构建用户

复制代码
create user u106761 with password 'Test01@123';

切换到普通用户

复制代码
set role u106761;

创建表

复制代码
CREATE TABLE xml_table (
    id NUMBER,
    xml_column XMLType
);
INSERT INTO xml_table (id, xml_column)
VALUES (1, XMLType('<root><name>John</name></root>'));

使用XMLType

复制代码
DECLARE
    v_clob CLOB;
BEGIN
    SELECT XMLType.getClobVal(xml_column) INTO v_clob FROM xml_table WHERE id = 1;
    DBMS_OUTPUT.PUT_LINE('CLOB value: ' || v_clob);
END;
/

CLOB value: <root><name>John</name></root>
DO

总结

普通用户可以正常调用XMLType的成员方法,不会报权限错误。

相关推荐
SelectDB1 小时前
SelectDB x 同辕开发:在 ARM 架构下实现 25% 分析性能提升
大数据·数据库·华为
华科云商xiao徐1 小时前
Rust+Python双核爬虫:高并发采集与智能解析实战
数据库·python·rust
Techie峰2 小时前
Redis Key过期事件监听Java实现
java·数据库·redis
lwb_01183 小时前
【数据库】使用Sql Server创建索引优化查询速度,一般2万多数据后,通过非索引时间字段排序查询出现超时情况
java·服务器·数据库
吴声子夜歌4 小时前
PostgreSQL——索引
数据库·postgresql·oracle
hj10439 小时前
redis开启局域网访问
数据库·redis·缓存
源代码•宸11 小时前
MySQL 索引:索引为什么使用 B+树?(详解B树、B+树)
数据结构·数据库·经验分享·b树·mysql·b+树·b-树
睡觉的时候不会困11 小时前
MySQL 数据库表操作与查询实战案例
数据库·mysql
秋已杰爱12 小时前
Redis常见命令
数据库·redis·缓存
一个有梦有戏的人12 小时前
软考架构师:数据库的范式
数据库·oracle