エージェンシーモデルエージェンシーモデルのORM ORM

仲介モデルをORM

 

 

仲介モデルとは何ですか

仲介モデルは、(多くの多くの)多対多を発行するときに第三のテーブル、

仲介モデルが実際に指し我々は、彼らが第三のテーブルを作成しない場合は、ジャンゴで3番目のテーブルを作成しませんが、私たちはジャンゴで作成された与えるということです、そして何の仲介モデルはありません

仲介モデル例

一般的な例多対多

クラスブック(models.Model):
    タイトル= models.CharField(max_lengthを= 32)
    (= '著者'まで)著者= models.ManyToManyField 

クラスの著者(models.Model):
    名前= models.CharField(max_lengthを= 32)

この時間は、Djangoは自動的に次のように私たちは、地面そのテーブルを作成するのに役立ちます。

仲介モデル小さなサンプル

クラスブック(models.Model):
    '' '' '' 
    タイトル= models.CharField(max_lengthを= 32)
    (=へ=作者models.ManyToManyField '' Book2Author '=通じ、'著者)

クラスの著者(models.Model):
    名前= models.CharField(max_lengthを= 32)

クラスBook2Author(models.Model):
    book_id = models.ForeignKey(= '帳'へ)
    AUTHOR_ID = models.ForeignKey(= '著者'まで)

次のようにこの時間は、それは、コマンドを管理し実行した後に第三のテーブルを生成します。

図は、フィールドに「_id」を追加するときはDjangoのForeignKeyが自動的に作成、見ることができるので、我々は次のように_idが第三のテーブルのフィールドを追加して書く時間がありません。

クラスブック(models.Model):
    '' '' '' 
    タイトル= models.CharField(max_lengthを= 32)
    (=へ=作者models.ManyToManyField '' Book2Author '=通じ、'著者)

クラスの著者(models.Model):
    名前= models.CharField(max_lengthを= 32)

クラスBook2Author(models.Model):
    book_id = models.ForeignKey(= '帳'へ)
    AUTHOR_ID = models.ForeignKey(= '著者'まで)

自作のテーブルとDjangoの差仲介モデル

1、あなたは任意の追加フィールドで独自に追加することができますので、3番目のテーブルの中間モデルは、自分で作成している、とDjangoの第三のテーブルからフィールドが固定されて作成されました

2、仲介モデルは、追加設定、削除、明確な方法はありません

 
 
 
 
 
 

 

仲介モデルとは何ですか

仲介モデルは、(多くの多くの)多対多を発行するときに第三のテーブル、

仲介モデルが実際に指し我々は、彼らが第三のテーブルを作成しない場合は、ジャンゴで3番目のテーブルを作成しませんが、私たちはジャンゴで作成された与えるということです、そして何の仲介モデルはありません

仲介モデル例

一般的な例多対多

クラスブック(models.Model):
    タイトル= models.CharField(max_lengthを= 32)
    (= '著者'まで)著者= models.ManyToManyField 

クラスの著者(models.Model):
    名前= models.CharField(max_lengthを= 32)

この時間は、Djangoは自動的に次のように私たちは、地面そのテーブルを作成するのに役立ちます。

仲介モデル小さなサンプル

クラスブック(models.Model):
    '' '' '' 
    タイトル= models.CharField(max_lengthを= 32)
    (=へ=作者models.ManyToManyField '' Book2Author '=通じ、'著者)

クラスの著者(models.Model):
    名前= models.CharField(max_lengthを= 32)

クラスBook2Author(models.Model):
    book_id = models.ForeignKey(= '帳'へ)
    AUTHOR_ID = models.ForeignKey(= '著者'まで)

次のようにこの時間は、それは、コマンドを管理し実行した後に第三のテーブルを生成します。

図は、フィールドに「_id」を追加するときはDjangoのForeignKeyが自動的に作成、見ることができるので、我々は次のように_idが第三のテーブルのフィールドを追加して書く時間がありません。

クラスブック(models.Model):
    '' '' '' 
    タイトル= models.CharField(max_lengthを= 32)
    (=へ=作者models.ManyToManyField '' Book2Author '=通じ、'著者)

クラスの著者(models.Model):
    名前= models.CharField(max_lengthを= 32)

クラスBook2Author(models.Model):
    book_id = models.ForeignKey(= '帳'へ)
    AUTHOR_ID = models.ForeignKey(= '著者'まで)

自作のテーブルとDjangoの差仲介モデル

1、あなたは任意の追加フィールドで独自に追加することができますので、3番目のテーブルの中間モデルは、自分で作成している、とDjangoの第三のテーブルからフィールドが固定されて作成されました

2、仲介モデルは、追加設定、削除、明確な方法はありません

 
 
 

仲介モデルとは何ですか

仲介モデルは、(多くの多くの)多対多を発行するときに第三のテーブル、

仲介モデルが実際に指し我々は、彼らが第三のテーブルを作成しない場合は、ジャンゴで3番目のテーブルを作成しませんが、私たちはジャンゴで作成された与えるということです、そして何の仲介モデルはありません

仲介モデル例

一般的な例多対多

クラスブック(models.Model):
    タイトル= models.CharField(max_lengthを= 32)
    (= '著者'まで)著者= models.ManyToManyField 

クラスの著者(models.Model):
    名前= models.CharField(max_lengthを= 32)

この時間は、Djangoは自動的に次のように私たちは、地面そのテーブルを作成するのに役立ちます。

仲介モデル小さなサンプル

クラスブック(models.Model):
    '' '' '' 
    タイトル= models.CharField(max_lengthを= 32)
    (=へ=作者models.ManyToManyField '' Book2Author '=通じ、'著者)

クラスの著者(models.Model):
    名前= models.CharField(max_lengthを= 32)

クラスBook2Author(models.Model):
    book_id = models.ForeignKey(= '帳'へ)
    AUTHOR_ID = models.ForeignKey(= '著者'まで)

次のようにこの時間は、それは、コマンドを管理し実行した後に第三のテーブルを生成します。

图中可以看出,Django创建ForeignKey的时候会在字段后自动添加'_id',所以,我们在写第三张表字段的时候就不用加_id了,如下:

class Book(models.Model):
    ''''''
    title = models.CharField(max_length=32)
    authors = models.ManyToManyField(to='Author',through='Book2Author')

class Author(models.Model):
    name = models.CharField(max_length=32)

class Book2Author(models.Model):
    book_id = models.ForeignKey(to='Book')
    author_id = models.ForeignKey(to='Author')

中介模型与Django自建表的区别

1、中介模型的第三张表是自己创建的,所以可以自己任意添加额外的字段,而Django自创建的第三张表的字段是固定的

2、中介模型没有add,set  , remove,clear 方法

おすすめ

転載: www.cnblogs.com/taosiyu/p/11223764.html