蚌埠市网站建设_网站建设公司_网站备案_seo优化
2026/1/15 13:37:48 网站建设 项目流程

文章目录

  • 环境
  • 症状
  • 问题原因
  • 解决方案

环境

系统平台:N/A
版本:4.7.6

症状

本文档解决了如何在函数数据库中调用UUID函数已经如何消除“-”显示的方法

问题原因

1、UUID函数的调用需要通过拓展(extension)来实现。

2、直接调用UUID函数显示的字符串会通过“-”来连接。

解决方案

一、创建并调用

测试环境
HighGo Database V4.7 Enterprise Edition Release 4.7.6 - 64-bit Production

创建uuid-ossp扩展:

highgo=# create extension "uuid-ossp";

日志: 00000: 语句: create extension “uuid-ossp”;

CREATEEXTENSION

查询uuid-ossp是否创建成功:

highgo=# \dx uuid-osspListofinstalled extensions Name|Version|Schema|Description-----------+---------+--------+-------------------------------------------------uuid-ossp|1.0|public|generate universallyuniqueidentifiers(UUIDs)(1row)

调用测试:

highgo=# select uuid_generate_v4();uuid_generate_v4--------------------------------------36ecc872-5f97-4471-a0e1-31d5e33716ce(1row)

二、不同模式下的调用

1、查看所有模式

product=# \dnListofschemas Name|Owner----------------+--------hgdb_catalog|highgo icp_business|test oracle_catalog|highgopublic|highgo test|highgo(5rows)

2、修改默认模式

product=# set search_path = icp_business,public,"$user";SETproduct=# show search_path ;search_path-------------------------------icp_business,public,"$user"(1row)

3、创建“UUID”

product=# create extension "uuid-ossp";CREATEEXTENSION product=# \dx uuid-ossp;Listofinstalled extensions Name|Version|Schema|Description-----------+---------+--------------+-------------------------------------------------uuid-ossp|1.0|icp_business|generate universallyuniqueidentifiers(UUIDs)(1row)

4、取消当前模式搜寻路径

product=# set search_path = public,"$user";SETproduct=# \dx uuid-ossp;Listofinstalled extensions Name|Version|Schema|Description-----------+---------+--------------+-------------------------------------------------uuid-ossp|1.0|icp_business|generate universallyuniqueidentifiers(UUIDs)(1row)

5、模拟相同问题

product=# select uuid_generate_v4();

错误: 42883: 函数 uuid_generate_v4() 不存在

LINE 1: select uuid_generate_v4();

^

HINT: 没有匹配指定名称和参数类型的函数. 您也许需要增加明确的类型转换.

6、重新设置模式路径
如果是要永久修改请使用:alter system set search_path = icp_business,public,“$user”;

product=# set search_path = icp_business,public,“$user”;

SET

7、重新调用

product=# select uuid_generate_v4();uuid_generate_v4--------------------------------------a2b4890a-2d41-4f12-8e5a-b2f68768d3da(1row)

三、关于-的显示替换

product=# select replace(uuid_generate_v4()::varchar,'-'::varchar,''::varchar);replace----------------------------------c520aba1909f4b9097983b00e22a4734(1row)product=# select sys_guid();sys_guid----------------------------------446d30950a2551d1a9aed4a03f446ef7(1row)

需要专业的网站建设服务?

联系我们获取免费的网站建设咨询和方案报价,让我们帮助您实现业务目标

立即咨询