Django之多表操作1
创建模型
创建一个多表模型
from django.db import models # 表app01_publish class Publish(models.Model): nid = models.AutoField(primary_key=True) name = models.CharField(max_length=20) # 表app01_book class Book(models.Model): nid = models.AutoField(primary_key=True) title = models.CharField(max_length=20) price = models.DecimalField(max_digits=8, decimal_places=2) pub_date = models.DateField() # 表app01_book多对一表app01_publish,参数to指定模型名,参数to_field指定要关联的那个字段 publish = models.ForeignKey(to='Publish',to_field='nid',on_delete=models.CASCADE) # 我们自己写sql时,针对书籍表与作者表的多对关系,需要自己创建新表,而基于django的orm,下面这一行代码可以帮我们自动创建那张关系表 authors=models.ManyToManyField(to='Author') # 变量名为authors,则新表名为app01_book_authors,若变量名为xxx,则新表名为app01_book_xxx # 表app01_author class Author(models.Model): nid = models.AutoField(primary_key=True) name = models.CharField(max_length=20) age = models.IntegerField() # 表app01_author一对一表app01_authordetail author_detail = models.OneToOneField(to='AuthorDetail',to_field='nid',unique=True,on_delete=models.CASCADE) # 表app01_authordetail class AuthorDetail(models.Model): nid = models.AutoField(primary_key=True) tel = models.CharField(max_length=20)
关键在于
在创建关联时,针对参数to,如果传入的是字符串(to="模型名"),则模型类的定义不区分先后顺序,如果传入的是模型名(to=Author),则Author类必须事先定义
添加、删除、修改记录
由于foreign key的关系,我们需要事先往app01_publish与app01_authordetail里插入记录
# 1、需求:通过模型Publish往表app01_publish里插入三家出版社 Publish.objects.create(name='北京出版社') Publish.objects.create(name='长春出版社') Publish.objects.create(name='大连出版社') # 2、需求:通过模型AuthorDetail往表app01_authordetail里插入三条作者详情 AuthorDetail.objects.create(tel='18611312331') AuthorDetail.objects.create(tel='15033413881') AuthorDetail.objects.create(tel='13011453220')
1、多对一:app01_book与app01_publish
# 需求:书籍(葵花宝典、菊花宝典、桃花宝典)都是在北京出版社出版的 # 1、先通过模型Publish从出版社表app01_publish查出北京出版社 publish_obj=Publish.objects.filter(name='北京出版社').first() # 上述代码也可以简写为:publish_obj=Publish.objects.get(name='北京出版社') # 2、再通过模型Book往书籍表app01_book里插入三本书籍与出版社的对应关系 # 方式一:使用publish参数指定关联 book_obj1=Book.objects.create(title='葵花宝典',price=2000,pub_date='1985-3-11',publish=publish_obj) book_obj2=Book.objects.create(title='菊花宝典',price=3000,pub_date='1990-1-21',publish=publish_obj) book_obj3=Book.objects.create(title='桃花宝典',price=4000,pub_date='1991-1-23',publish=publish_obj) # 方式二:使用publish_id参数指定关联 book_obj1=Book.objects.create(title='葵花宝典',price=2000,pub_date='1985-3-11',publish_id=publish_obj.nid) book_obj2=Book.objects.create(title='菊花宝典',price=3000,pub_date='1990-1-21',publish_id=1) # 在已经出版社id的情况下,可以直接指定 book_obj3=Book.objects.create(title='桃花宝典',price=4000,pub_date='1991-1-23',publish_id=1) # 注意:无论方式一还是方式二得到的书籍对象book_obj1、book_obj2、book_obj3 # 都可以调用publish字段来访问关联的那一个出版社对象 # 都可以调用publish_id来访问关联的那一个出版社对象的nid print(book_obj1.publish,book_obj1.publish_id) print(book_obj2.publish,book_obj2.publish_id) print(book_obj3.publish,book_obj3.publish_id) # 三本书关联的是同一个出版社,所以输出结果均相同
参照上述步骤,把剩余三本书与出版社的对应关系也插入
book_obj1 = Book.objects.create(title='玉女心经', price=5000, pub_date='1988-3-24', publish_id=2) book_obj2 = Book.objects.create(title='玉男心经', price=3000, pub_date='1985-6-17', publish_id=2) book_obj3 = Book.objects.create(title='九阴真经', price=6000, pub_date='1983-8-17', publish_id=3)
2、一对一:app01_author与app01_authordetail
# 需求:插入三个作者,并与作者详情表一一对应 # 由于作者详情表我们已经事先创建好记录,所以只需要往作者表插入记录即可 # 方式一:需要事先过滤出作者详情的对象,然后通过模型Author的字段author来指定要关联的作者详情对象(略) # 方式二:确定作者详情对象的id,然后通过模型Author通过字段author_id来指定关联关系, Author.objects.create(name='egon',age=18,author_detail_id=1) Author.objects.create(name='kevin',age=38,author_detail_id=2) Author.objects.create(name='rose',age=28,author_detail_id=3)
3、多对多:app01_book与app01_author
# 我们参照物理表app01_book_authors制定需求,需要创建如下关系 # 1、葵花宝典的作者为:egon、kevin # 2、菊花宝典的作者为:egon、kevin、rose # 3、桃花宝典的作者为:egon、kevin # 4、玉女心经的作者为:kevin、rose # 5、玉男心经的作者为:kevin # 6、九阴真经的作者为:egon、rose # 需要创建出上述关系,具体做法如下 # 1、先获取书籍对象 book_obj1=Book.objects.get(title='葵花宝典') book_obj2=Book.objects.get(title='菊花宝典') book_obj3=Book.objects.get(title='桃花宝典') book_obj4=Book.objects.get(title='玉女心经') book_obj5=Book.objects.get(title='玉男心经') book_obj6=Book.objects.get(title='九阴真经') # 2、然后获取作者对象 egon=Author.objects.get(name='egon') kevin=Author.objects.get(name='kevin') rose=Author.objects.get(name='rose') # 3、最后依次创建上述关系:在原生SQL中多对多关系涉及到操作第三张关系表,但是在ORM中我们只需要操作模型类Book下的字段author即可 book_obj1.authors.add(egon,kevin) book_obj2.authors.add(egon,kevin,rose) book_obj3.authors.add(egon,kevin) book_obj4.authors.add(kevin,rose) book_obj5.authors.add(kevin) book_obj6.authors.add(egon,rose)

浙公网安备 33010602011771号