- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
几天前,我开始将 Elixir 和 Phoenix Framework (v 0.12.0) 与 Postgres 数据库一起使用。我正在尝试创建一个具有 UUID 主键的表,我更喜欢顺序默认值。
在使用mix phoenix.gen.html
生成模型和迁移文件并遵循 Phoenix 文档中的其他步骤后,我进行了更改
def model do
quote do
use Ecto.Model
end
end
在web.ex
中
def model do
quote do
use Ecto.Model
@primary_key {:id, :uuid, []}
@foreign_key_type :uuid
end
end
如 Ecto 文档中所述。我还将迁移更改为
create table(:tblname, primary_key: false) do
add :id, :uuid, primary_key: true
[other columns]
end
不幸的是,当我尝试从自动生成的表单向表中添加条目时,我收到错误消息,因为 id
为空。如果我手动将 id
列添加到模型中,我会收到一条错误消息,指出该列已存在。如果我忽略在 table/2
中将 primary_key
设置为 false 并删除 id
列,则生成的表具有顺序 id
-列。
我是否需要在变更集中手动设置 id
,或者我在将我的应用设置为使用 UUID 时犯了错误?提前致谢
最佳答案
编辑:我已将此答案更新为 Ecto v2.0。您可以在最后阅读之前的答案。
自最初的答案以来,在 Ecto 中处理 UUID 变得更加直接。 Ecto 有两种类型的 ID::id
和 :binary_id
。第一个是我们从数据库中知道的整数 ID,第二个是特定于数据库的二进制文件。对于 Postgres,它是一个 UUID。
要将 UUID 作为主键,首先在迁移中指定它们:
create table(:posts, primary_key: false) do
add :id, :binary_id, primary_key: true
end
然后在您的模型模块中(在 schema
block 之外):
@primary_key {:id, :binary_id, autogenerate: true}
当您为:binary_id
指定:autogenerate
选项时,Ecto 将保证适配器或数据库会为您生成它。但是,如果您愿意,您仍然可以手动生成它。顺便说一句,您可以在迁移中使用 :uuid
并在架构中使用 Ecto.UUID
而不是 :binary_id
,这是 的好处:binary_id
是它可以跨数据库移植。
您需要告诉您的数据库如何自动为您生成 UUID。或者您需要从应用程序端生成一个。这取决于您喜欢哪一个。
在我们继续之前,重要的是要说明您正在使用 :uuid
,它将返回二进制文件而不是人类可读的 UUID。您很可能想使用 Ecto.UUID
,它将其格式化为字符串 (aaaa-bbb-ccc-...),这就是我将在下面使用的内容。
在您的迁移中,为该字段定义一个默认值:
add :id, :uuid, primary_key: true, default: fragment("uuid_generate_v4()")
我假设您在 PostgreSQL 上运行。您需要在 pgAdmin 中使用 CREATE EXTENSION "uuid-ossp"
安装 uuid-ossp 扩展,或者在迁移中添加 execute "CREATE EXTENSION\"uuid-ossp\""
.有关 the UUID generator can be found here 的更多信息.
回到 Ecto,在你的模型中,要求 Ecto 在插入/更新后从数据库中读取字段:
@primary_key {:id, Ecto.UUID, read_after_writes: true}
现在,当你插入时,数据库会生成一个默认值,Ecto 会读回它。
您需要定义一个为您插入 UUID 的模块:
defmodule MyApp.UUID do
def put_uuid(changeset) do
Ecto.Changeset.put_change(changeset, :id, Ecto.UUID.generate())
end
end
并将其用作回调:
def model do
quote do
use Ecto.Model
@primary_key {:id, Ecto.UUID, []}
@foreign_key_type Ecto.UUID
before_insert MyApp.UUID, :put_uuid, []
end
end
before_insert
是一个回调函数,它将使用给定的参数在给定的函数中调用给定的模块,其中一个代表正在插入的内容的变更集作为第一个参数给出。
应该就这些了。顺便说一句,将来这可能会更加精简。 :)
关于postgresql - 设置 Phoenix Framework 和 Ecto 以使用 UUID : how to insert the generated value?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30004008/
我试图再次将反射的 UUID 转换回实际的 UUID 对象,但找不到方法,当我打印反射值时它看起来是正确的,但在尝试转换时我找不到方法。 package main import ( "fmt"
我想知道 UUID 是否是唯一的,即使它们是在不同的系统上生成的,这些系统可能采用不同的算法。例如,如果您在 MySQL 和 .Net 中生成了一堆 UUID,碰撞的可能性会更高,还是所有系统都使用完
是否可以一个接一个地创建两个重复的 UUID?我不熟悉 UUID 是如何生成的,但我猜想如果您在同一毫秒内从同一 MAC 地址创建了两个单独的 UUID,那么它们将完全相同。这是真的吗? 我想我是在问
当我使用 python uuid 模块中的 UUID() 函数检查我们的测试 uuid 之一时,我遇到了这种奇怪的行为。 从 uuid 导入 UUID uuid1 = UUID('00000000-0
开始使用 java.util.UUID。我的问题是如果我有两个 UUID 变量,比如 u1 和 u2,并且我想检查它们是否相等,我可以安全地使用表达式 u1 == u2 还是必须编写 u1 .equa
我浏览了 python UUID 模块的文档。 >>> uuid.uuid4() UUID('82fe5629-6680-4b13-a4e3-7a082f10e038') >>> uuid.uuid4
我正在创建一个程序,我在其中大量使用 UUID 来识别用户和组等内容。鉴于 UUID 已经被占用的可能性极低,我是否应该担心发生碰撞的可能性? 最佳答案 这在很大程度上取决于 A)您的要求 B)底层实
您应该使用哪个版本的 UUID?我看到很多帖子解释了每个版本的含义,但我很难弄清楚什么最适合哪些应用程序。 最佳答案 有两种不同的方式生成 UUID。 如果您只需要一个唯一 ID,则需要版本 1 或版
我知道我们可以轻松提取 uuid 版本号。有没有可靠的方法来提取时间戳、MAC 地址等信息? 谢谢! 最佳答案 符合标准的 UUID 可能是多种变体之一,它看起来像这样: AAAAAAAA-BBBB-
我可以干净地使用私有(private) UUID 变体/版本吗? 我使用我基本上认为是大整数的随机 UUID。现在,我想生成一个“私有(private)”UUID,它不基于众所周知的 5 个变体/版本
我已阅读 man 页面,但我不明白 name 和 namespace 的用途。 For version 3 and version 5 UUIDs the additional command lin
我目前正在项目中使用 boost::uuids::uuid,并且我想序列化包含 boost::uuids::uuid 的对象。我尝试了下面的简单示例,但出现错误: /usr/include/boost
我正在使用 Datastax Java 驱动程序在 Cassandra 数据库中执行基本的插入语句。我的主键列是uuid类型。从我在官方文档中看到的,在 Cassandra 中调用 uuid() 函数
会抛出异常吗? UUID() 是否会悄无声息地失败?是否有任何情况下“myStatus”来自 myStatus = True myUUID = uuid.UUID( someWeirdValue )
在我的 Android 应用程序中,我有这种采用 UUID 的方法。不幸的是,当我这样做时: OverviewEvent overviewevent = eventAdapter.getOvervie
我有一个简单的 mongo 迁移框架,它正在执行一些传递给它的脚本。 现在我想将我的 LUUID 迁移到 UUID。我写了以下内容: function fixIds(collectionName) {
我有一个非常奇怪的问题是我得到一个有效的 UUID 不是一个有效的 UUID,例如: 'fd31b6b5-325d-4b65-b496-d7e4d16c8a93' is not a valid UUI
我正在测试 Goa对于一个 API。我想使用 uuid 作为 ID 数据类型。我在 controller.go 中修改了以下函数: // Show runs the show action. func
我有一个包含 uuid 和系统列的表。我需要一个查询来仅返回具有 system=1 的 uuid,而不返回具有 system= 1 和 2 的 uuid 最佳答案 SELECT * FROM
我很想了解在 Avro 中编码一种非常特定类型的数据的最佳实践:UUID。 最佳答案 到目前为止,我发现的唯一方法是定义自定义 UUID: { "namespace" : "your.namesp
我是一名优秀的程序员,十分优秀!