首页 > 代码库 > 转: django数据库操作-增删改查-多对多关系以及一对多(外键)关系
转: django数据库操作-增删改查-多对多关系以及一对多(外键)关系
原文链接:http://blog.csdn.net/u010271717/article/details/22044415
一、一对多(外键)
例子:一个作者对应多本书,一本书只有一个作者
model代码:
[python] view plain copy
- class Person(models.Model);
- name = models.CharField(‘作者姓名‘, max_length=10)
- age = models.IntegerField(‘作者年龄‘)
- class Book(models.Model):
- person = models.ForeignKey(Person, related_name=‘person_book‘)
- title = models.CharField(‘书籍名称‘, max_length=10)
- pubtime = models.DateField(‘出版时间‘)
(一)获取对象方法:
1.从作者出发获取书籍
[python] view plain copy
- person = Person.objects.fiter(你的条件)
- book = person.book_set.all()
2.从书籍出发获取作者
[python] view plain copy
- p = book.person
二、多对多
例子:一个作者对应多本书,一本书有多个作者
model代码:
[python] view plain copy
- class Author(models.Model):
- first_name = models.CharField(max_length=30)
- last_name = models.CharField(max_length=40)
- email = models.EmailField()
- class Book(models.Model):
- title = models.CharField(max_length=200)
- authors = models.ManyToManyField(Author)
(一)获取对象方法:
1.从书籍出发获取作者
[python] view plain copy
- b = Book.objects.get(id=50)
- b.authors.all()
- b.authors.filter(first_name=‘Adam‘)
2.从作者出发获取书籍
[python] view plain copy
- a = Author.objects.get(id=1)
- a.book_set.all()
(二)添加对象方法:
[python] view plain copy
- a = Author.objects.get(id=1)
- b = Book.objects.get(id=50)
- b.authors.add(a)
(三)删除对象对象方法:
[python] view plain copy
- a = Author.objects.get(id=1)
- b = Book.objects.get(id=50)
- b.authors.remove(a) 或者 b.authors.filter(id=1).delete()
转: django数据库操作-增删改查-多对多关系以及一对多(外键)关系
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。