金仓R3如何改变sys_guid() 返回值类型


sys_guid函数默认返回的是16进制的串的ascii编码,通过修改参数guid_default_return_type=name,可以返回16进制字符串,但修改参数时,会发现参数实际已修改,但没效果。
以上问题是由于修改过程没有运行alter_sys_guid()函数导致的。修改过程如下:
修改参数guid_default_return_type;
重启数据库;
执行 select alter_sys_guid() 。这个实际是重建sys_guid()函数,根据参数guid_default_return_type决定是调用sys_guid_bytea ,还是调用sys_guid_name。
Alter_sys_guid 函数的内容:
begin                                                                                                                                                            
  select setting into return_type from sys_catalog.sys_settings where name = 'guid_default_return_type';                                                         
  if lower(return_type) = 'bytea' then                                                                                                                           
    stmt = 'DROP FUNCTION IF EXISTS sys_catalog.sys_guid(); 
      CREATE OR REPLACE INTERNAL FUNCTION sys_catalog.sys_guid() RETURNS BYTEA AS 
$$SELECT sys_catalog.sys_guid_bytea()$$ LANGUAGE sql;';
  else                                                                                                                                                           
    stmt = 'DROP FUNCTION IF EXISTS sys_catalog.sys_guid(); 
      CREATE OR REPLACE INTERNAL FUNCTION sys_catalog.sys_guid() RETURNS NAME AS 
$$SELECT sys_catalog.sys_guid_name()$$ LANGUAGE sql;';  
  end if; 
end;   
Note: 对于R6 版本,没有alter_sys_guid,需要手动修改创建脚本。

  • 11
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值