Eliir Ecto: PostgreSQL大自增长主键的设置
要解决的问题
数据库中存储的行数超过了 serial 类型所能容纳的数量, 因此需要采用 bigserial 类型的整数作为主键
serial 的取值范围为: 1 到 2147483647
bigserial 的取值范围为: 1 到 9223372036854775807
完整的 Postgresql 字段的数据类型, 可以参考这里
迁移脚本
defmodule ElectricProto.Repo.Migrations.AddStationTable do
use Ecto.Migration
def up do
create table(:station, primary_key: false) do
add :id, :bigserial, primary_key: true
timestamps
end
end
def down do
drop table(:station)
end
end
要点
create table的参数primary_key要设置为false,
通过add宏指定主键列id, 类型为bigserial
模型的声明
@primary_key {:id, :id, autogenerate: true}
schema "station" do
field :area, :string, default: ""
field :carrier, :string, default: ""
field :city, :string, default: ""
field :deployed, :boolean, default: false
field :description, :string, default: ""
field :device_auth, :string, default: ""
field :device_type, :string, default: ""
field :geolocation, :string, default: ""
field :ip_addr, :string, default: ""
field :qrcode, :string, default: ""
field :station_id, :string, default: ""
field :status, :string, default: ""
timestamps
end
要点
- 主键要声明为:id类型, @primary_key {:id, :id, autogenerate: true}
完!
关键字:elixir, ecto
版权声明
本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处。如若内容有涉嫌抄袭侵权/违法违规/事实不符,请点击 举报 进行投诉反馈!