我的问题很简单。我知道一个UUID的概念,我想生成一个引用每个“项目”从一个“商店”在我的DB与。似乎很合理,对吧?
问题是下面这行返回了一个错误:
honeydb=# insert into items values(
uuid_generate_v4(), 54.321, 31, 'desc 1', 31.94);
ERROR: function uuid_generate_v4() does not exist
LINE 2: uuid_generate_v4(), 54.321, 31, 'desc 1', 31.94);
^
HINT: No function matches the given name and argument types. You might need to add explicit type casts.
我已经在http://www.postgresql.org/docs/current/static/uuid-ossp.html上阅读了页面
我在Ubuntu 10.04 x64上运行Postgres 8.4。
2021年起更新,
不需要在插入语句中自动生成uuid。
只做一件事:
将default gen_random_uuid()的默认值设置为您的uuid列。
仅此而已。
假设,你有一个这样的表:
CREATE TABLE table_name (
unique_id UUID DEFAULT gen_random_uuid (),
first_name VARCHAR NOT NULL,
last_name VARCHAR NOT NULL,
email VARCHAR NOT NULL,
phone VARCHAR,
PRIMARY KEY (unique_id)
);
现在你不需要做任何事情来自动插入uuid值到unique_id列。因为您已经为它定义了一个默认值。你可以简单地专注于插入到其他列上,而postgresql会处理你的unique_id。下面是一个插入语句示例:
INSERT INTO table_name (first_name, last_name, email, phone)
VALUES (
'Beki',
'Otaev',
'beki@bekhruz.com',
'123-456-123'
)
注意,没有插入到unique_id,因为它已经被处理了。
关于其他扩展,如uuid-ossp,如果您对postgres的标准gen_random_uuid()函数不满意,可以启用它们。大多数时候,你不戴眼镜也没问题
Uuid-ossp是一个贡献模块,所以默认情况下它不会被加载到服务器中。必须将其加载到数据库中才能使用。
对于现代PostgreSQL版本(9.1及更新版本),这很容易:
CREATE EXTENSION IF NOT EXISTS "uuid-ossp";
但是对于9.0及以下版本,您必须运行SQL脚本来加载扩展。请参阅8.4中有关contrib模块的文档。
对于Pg 9.1和更新版本,请阅读当前的contrib文档和CREATE EXTENSION。这些特性在9.0或更早的版本(如8.4)中不存在。
如果你正在使用PostgreSQL的打包版本,你可能需要安装一个包含contrib模块和扩展的单独包。在包管理器数据库中搜索'postgres'和'contrib'。
Craig Ringer的答案是正确的。下面是关于Postgres 9.1及以后版本的一些信息…
分机是否可用?
您只能安装已经为Postgres安装(Postgres行话是您的集群)构建的扩展。例如,我发现uuid-ossp扩展是由EnterpriseDB.com好心提供的Mac OS X安装程序的一部分。几十个扩展中的任何一个都可能可用。
要查看uuid-ossp扩展在Postgres集群中是否可用,运行下面的SQL查询pg_available_extensions系统目录:
SELECT * FROM pg_available_extensions;
安装扩展
要安装uuid相关的扩展,使用CREATE extension命令,如下面的SQL所示:
CREATE EXTENSION IF NOT EXISTS "uuid-ossp";
注意:我发现扩展名周围的引号字符是必需的,尽管文档与此相反。
SQL标准委员会或Postgres团队为该命令选择了一个奇怪的名称。在我看来,他们应该选择“安装扩展”或“使用扩展”之类的东西。
验证安装
您可以通过运行下面的SQL查询pg_extension系统目录来验证扩展是否成功安装在所需的数据库中:
SELECT * FROM pg_extension;
UUID为默认值
有关更多信息,请参阅问题:Postgres中UUID列的默认值
旧的方式
上面的信息使用了Postgres 9.1中新增的扩展特性。在以前的版本中,我们必须在.sql文件中找到并运行脚本。扩展特性的添加使安装变得更容易,为扩展的创建者提供了更多的工作,从而减少了扩展的用户/消费者的工作。更多讨论请参阅我的博客文章。
uuid的类型
顺便说一下,问题中的代码调用函数uuid_generate_v4()。这将生成一种称为版本4的类型,其中几乎所有的128位都是随机生成的。虽然这对于在较小的行集上有限地使用是可以的,但如果您希望实际上消除任何冲突的可能性,请使用另一个“版本”的UUID。
例如,原始版本1将主机的MAC地址与当前日期-时间和任意数字结合在一起,碰撞的机会几乎为零。
有关更多讨论,请参阅我对相关问题的回答。
uuid-ossp模块提供了生成uuid (universally unique identifier)的函数。
uuid_generate_v1()该函数生成版本1的UUID。
添加扩展
如果“uuid-ossp”不存在,则创建扩展;
验证扩展
SELECT * FROM pg_extension;
运行查询
INSERT INTO table_name(id, columnn1, column2, column3,…)值
(uuid_generate_v1(), value1, value2, value3…);
验证表数据