TAG 21
作者
digoal
日期
2016-03-15
标签
PostgreSQL , Oracle , 兼容性 , UUID , sys_guid
背景
Oracle 使用sys_guid()用来产生UUID值。
在PostgreSQL中有类似的函数,需要安装uuid-ossp插件。
如果用户不想修改代码,还是需要使用sys_guid()函数的话,可以自己写一个。
如下:
```
postgres=# create extension "uuid-ossp";
CREATE EXTENSION
postgres=# create or replace function sys_guid() returns uuid as $$
select uuid_generate_v4();
$$ language sql strict;
CREATE FUNCTION
postgres=# select sys_guid();
sys_guid
92bbbf05-a23c-41b3-95d4-8732c93d95dd
(1 row)
postgres=# select sys_guid();
sys_guid
37e34cfb-46aa-44ed-9403-9e23b6c2bfc0
(1 row)
```
如果需要长度一致的格式,请使用如下方法转换
``` postgres=# select replace(uuid_generate_v4()::text,'-',''); replace
ac8fa20c88ad4f78b64c7223d3afb6a0 (1 row)
```
封装
``` postgres=# create or replace function sys_guid() returns text as $$ select replace(uuid_generate_v4()::text,'-',''); $$ language sql strict; CREATE FUNCTION
postgres=# select sys_guid(); sys_guid
f7ec00b55b9343319fbae185957f2e5e (1 row) ```
PostgreSQL 许愿链接
您的愿望将传达给PG kernel hacker、数据库厂商等, 帮助提高数据库产品质量和功能, 说不定下一个PG版本就有您提出的功能点. 针对非常好的提议,奖励限量版PG文化衫、纪念品、贴纸、PG热门书籍等,奖品丰富,快来许愿。开不开森.
9.9元购买3个月阿里云RDS PostgreSQL实例
PostgreSQL 解决方案集合
德哥 / digoal's github - 公益是一辈子的事.





