メインコンテンツへスキップする

はじめに

簡単な概要

スキーマには、グラフ内の 1 つのエンティティタイプの定義が記述されています。 UserGroup のように、以下の構成を含めることができます。

  • エンティティフィールド (またはプロパティ) 。例えば、 User の名前や年齢。
  • エンティティエッジ(またはリレーション)。例えば、 Userのグループ、 Userのフレンド。
  • データベース固有のオプション。例えば、インデックスや一意インデックスなど。

スキーマの例を次に示します。

package schema

import (
"entgo.io/ent"
"entgo.io/ent/schema/field"
"entgo.io/ent/schema/edge"
"entgo.io/ent/schema/index"
)

type User struct {
ent.Schema
}

func (User) Fields() []ent.Field {
return []ent.Field{
field.Int("age"),
field.String("name"),
field.String("nickname").
Unique(),
}
}

func (User) Edges() []ent.Edge {
return []ent.Edge{
edge.To("groups", Group.Type),
edge.To("friends", User.Type),
}
}

func (User) Indexes() []ent.Index {
return []ent.Index{
index.Fields("age", "name").
Unique(),
}
}

エンティティスキーマは、通常、プロジェクトのルート・ディレクトリ直下の ent/schema ディレクトリに格納されており、 entc では以下のようにして生成できます。

go run -mod=mod entgo.io/ent/cmd/ent new User Group
いくつかのスキーマ名は(Clientなど) Ent内部で予約されているため 利用できないことに注意してください ここで紹介するアノテーションを利用することで、予約された名前を回避できます。 :::

よくある一つのORM

エッジ上でのリレーションの定義に慣れているなら、素晴らしいです。 モデリングは同じです。 他の伝統的なORMでモデリングできることは、ent でモデリングできます。 There are many examples in this website that can help you get started in the Edges section.