django 学习-10 Django多对多关系模型

1、vim blog/models.py

class   Author(models.Model):

    name = models.CharField(max_length=30)

    def unicode(self):

        return self.name

class Book(models.Model):

    name = models.CharField(max_length=30)

    authors = models.ManyToMany(Author)

  def unicode(self):

    return self.name

2、python manage.py syncdb

sqlite3  cs.db

.tables;

3、python manage.py   shell

   from blog.models import Author,Book

Author.objects.create(name='a1')
Author.objects.create(name='a2')

authors = Author.objects.all()

>>> authors
[<Author: a1>, <Author: a2>]
>>> b1 = Book()
>>> b1.name='book1'
>>> b1.save()
>>> b1
<Book: book1>

a1 = Author.objects.get(name__exact='a1')

b1.authors.add(a1)

b1.authors.all()

b1.authors.remove(a1)

b1.authors.all()

b1.authors.filter(name__exact='a1')   做一个过滤

a1.book_set.add(b1)

a1.book_set.create(name='book2')

a1.book_set.all()

books = Book.objects.all()

books

a1.book_set.remove(books[0])   0是下标,表示把第一个删除

a1.book_set.all()

原文地址:https://www.cnblogs.com/Icanflyssj/p/5131528.html