1. 关联

1.1 模型类关系

关系型数据库的关系包括三种类型:

  • ForeignKey:一对多,将字段定义在多的一端中。
  • ManyToManyField:多对多,将字段定义在任意一端中。
  • OneToOneField:一对一,将字段定义在任意一端中。

1.1.1 一对多关系

#定义图书模型类BookInfo
class BookInfo(models.Model):
btitle = models.CharField(max_length=20)#图书名称
bpub_date = models.DateField()#发布日期
bread = models.IntegerField(default=0)#阅读量
bcomment = models.IntegerField(default=0)#评论量
isDelete = models.BooleanField(default=False)#逻辑删除 #定义角色模型类RoleInfo
class RoleInfo(models.Model):
rname = models.CharField(max_length=20)#角色姓名
rgender = models.BooleanField(default=True)#角色性别
isDelete = models.BooleanField(default=False)#逻辑删除
rcomment = models.CharField(max_len角色与图书表的关系为一对多,所以属性定义在角色模型类中

1.1.2 多对多关系

我们下面设计一个新闻类和新闻类型类,一个新闻类型下可以用很多条新闻,一条新闻也可能归属于多种新闻类型。

class TypeInfo(models.Model):
tname = models.CharField(max_length=20) #新闻类别 class NewsInfo(models.Model):
ntitle = models.CharField(max_length=60) #新闻标题
ncontent = models.TextField() #新闻内容
npub_date = models.DateTimeField(auto_now_add=True) #新闻发布时间
ntype = models.ManyToManyField('TypeInfo') #通过ManyToManyField建立TypeInfo类和NewsInfo类之间多对多的关系

1.2 关联查询

Django中也能实现类似于join查询。

1.2.1 通过对象执行关联查询

在定义模型类时,可以指定三种关联关系,最常用的是一对多关系,例如“图书-角色”就是一对多关系。

#一对应的模型类对象.多对应的模型类名小写_set

b = BookInfo.objects.get(id=1)
b.heroinfo_set.all()

由多到一的访问语法:

#多对应的模型类对象.多对应的模型类中的关系类属性名

r = RoleInfo.objects.get(id=1)
r.rbook

访问一对应的模型类关联对象的id语法:

#多对应的模型类对象.关联类属性_id

r = RoleInfo.objects.get(id=1)
r.book_id

例:查询编号为1的图书。

book=BookInfo.objects.get(pk=1)

例:获得book图书的所有角色。

book.roleinfo_set.all()

例:获得编号为1的角色。

role=RoleInfo.objects.get(pk=1)

例:获得role角色出自的图书。

role.rbook

1.2.2 通过模型类执行关联查询

由多模型类条件查询一模型类数据:

语法如下:

关联模型类名小写__属性名__条件运算符=值

如果没有"__运算符"部分,表示等于,结果和sql中的inner join相同。

例:查询图书,要求图书中英雄的描述包含'韩'。

list = BookInfo.objects.filter(heroinfo__hcontent__contains='韩')

由一模型类条件查询多模型类数据:

语法如下:

一模型类关联属性名__一模型类属性名__条件运算符=值

例:查询书名为“斗罗大陆”的所有英雄。

list = HeroInfo.objects.filter(hbook__btitle='斗罗大陆')

1.3 自关联

对于地区信息、分类信息等数据,表结构非常类似,每个表的数据量十分有限,为了充分利用数据表的大量数据存储功能,可以设计成一张表,内部的关系字段指向本表的主键,这就是自关联的表结构。

打开booktest/models.py文件,定义AreaInfo类。

关系属性使用self指向本类,要求null和blank允许为空,因为一级数据是没有父级的。

#定义地区模型类,存储省、市、区县信息
class AreaInfo(models.Model):
atitle=models.CharField(max_length=30)#名称
aParent=models.ForeignKey('self',null=True,blank=True)#关系

迁移。

python manage.py makemigrations
python manage.py migrate

打开mysql命令行,导入数据。

INSERT INTO booktest_areainfo VALUES ('', '广东省', NULL);
INSERT INTO booktest_areainfo VALUES ('', '广州市', '');
INSERT INTO booktest_areainfo VALUES ('', '荔湾区', '');
INSERT INTO booktest_areainfo VALUES ('', '越秀区', '');
INSERT INTO booktest_areainfo VALUES ('', '海珠区', '');
INSERT INTO booktest_areainfo VALUES ('', '天河区', '');
INSERT INTO booktest_areainfo VALUES ('', '白云区', '');
INSERT INTO booktest_areainfo VALUES ('', '黄埔区', '');
INSERT INTO booktest_areainfo VALUES ('', '番禺区', '');
INSERT INTO booktest_areainfo VALUES ('', '花都区', '');
INSERT INTO booktest_areainfo VALUES ('', '南沙区', '');
INSERT INTO booktest_areainfo VALUES ('', '萝岗区', '');
INSERT INTO booktest_areainfo VALUES ('', '增城市', '');
INSERT INTO booktest_areainfo VALUES ('', '从化市', '');
INSERT INTO booktest_areainfo VALUES ('', '韶关市', '');
INSERT INTO booktest_areainfo VALUES ('', '武江区', '');
INSERT INTO booktest_areainfo VALUES ('', '浈江区', '');
INSERT INTO booktest_areainfo VALUES ('', '曲江区', '');
INSERT INTO booktest_areainfo VALUES ('', '始兴县', '');
INSERT INTO booktest_areainfo VALUES ('', '仁化县', '');
INSERT INTO booktest_areainfo VALUES ('', '翁源县', '');
INSERT INTO booktest_areainfo VALUES ('', '乳源瑶族自治县', '');
INSERT INTO booktest_areainfo VALUES ('', '新丰县', '');
INSERT INTO booktest_areainfo VALUES ('', '乐昌市', '');
INSERT INTO booktest_areainfo VALUES ('', '南雄市', '');
INSERT INTO booktest_areainfo VALUES ('', '深圳市', '');
INSERT INTO booktest_areainfo VALUES ('', '罗湖区', '');
INSERT INTO booktest_areainfo VALUES ('', '福田区', '');
INSERT INTO booktest_areainfo VALUES ('', '南山区', '');
INSERT INTO booktest_areainfo VALUES ('', '宝安区', '');
INSERT INTO booktest_areainfo VALUES ('', '龙岗区', '');
INSERT INTO booktest_areainfo VALUES ('', '盐田区', '');
INSERT INTO booktest_areainfo VALUES ('', '珠海市', '');
INSERT INTO booktest_areainfo VALUES ('', '香洲区', '');
INSERT INTO booktest_areainfo VALUES ('', '斗门区', '');
INSERT INTO booktest_areainfo VALUES ('', '金湾区', '');
INSERT INTO booktest_areainfo VALUES ('', '汕头市', '');
INSERT INTO booktest_areainfo VALUES ('', '龙湖区', '');
INSERT INTO booktest_areainfo VALUES ('', '金平区', '');
INSERT INTO booktest_areainfo VALUES ('', '濠江区', '');
INSERT INTO booktest_areainfo VALUES ('', '潮阳区', '');
INSERT INTO booktest_areainfo VALUES ('', '潮南区', '');
INSERT INTO booktest_areainfo VALUES ('', '澄海区', '');
INSERT INTO booktest_areainfo VALUES ('', '南澳县', '');
INSERT INTO booktest_areainfo VALUES ('', '佛山市', '');
INSERT INTO booktest_areainfo VALUES ('', '禅城区', '');
INSERT INTO booktest_areainfo VALUES ('', '南海区', '');
INSERT INTO booktest_areainfo VALUES ('', '顺德区', '');
INSERT INTO booktest_areainfo VALUES ('', '三水区', '');
INSERT INTO booktest_areainfo VALUES ('', '高明区', '');
INSERT INTO booktest_areainfo VALUES ('', '江门市', '');
INSERT INTO booktest_areainfo VALUES ('', '蓬江区', '');
INSERT INTO booktest_areainfo VALUES ('', '江海区', '');
INSERT INTO booktest_areainfo VALUES ('', '新会区', '');
INSERT INTO booktest_areainfo VALUES ('', '台山市', '');
INSERT INTO booktest_areainfo VALUES ('', '开平市', '');
INSERT INTO booktest_areainfo VALUES ('', '鹤山市', '');
INSERT INTO booktest_areainfo VALUES ('', '恩平市', '');
INSERT INTO booktest_areainfo VALUES ('', '湛江市', '');
INSERT INTO booktest_areainfo VALUES ('', '赤坎区', '');
INSERT INTO booktest_areainfo VALUES ('', '霞山区', '');
INSERT INTO booktest_areainfo VALUES ('', '坡头区', '');
INSERT INTO booktest_areainfo VALUES ('', '麻章区', '');
INSERT INTO booktest_areainfo VALUES ('', '遂溪县', '');
INSERT INTO booktest_areainfo VALUES ('', '徐闻县', '');
INSERT INTO booktest_areainfo VALUES ('', '廉江市', '');
INSERT INTO booktest_areainfo VALUES ('', '雷州市', '');
INSERT INTO booktest_areainfo VALUES ('', '吴川市', '');
INSERT INTO booktest_areainfo VALUES ('', '茂名市', '');
INSERT INTO booktest_areainfo VALUES ('', '茂南区', '');
INSERT INTO booktest_areainfo VALUES ('', '茂港区', '');
INSERT INTO booktest_areainfo VALUES ('', '电白县', '');
INSERT INTO booktest_areainfo VALUES ('', '高州市', '');
INSERT INTO booktest_areainfo VALUES ('', '化州市', '');
INSERT INTO booktest_areainfo VALUES ('', '信宜市', '');
INSERT INTO booktest_areainfo VALUES ('', '肇庆市', '');
INSERT INTO booktest_areainfo VALUES ('', '端州区', '');
INSERT INTO booktest_areainfo VALUES ('', '鼎湖区', '');
INSERT INTO booktest_areainfo VALUES ('', '广宁县', '');
INSERT INTO booktest_areainfo VALUES ('', '怀集县', '');
INSERT INTO booktest_areainfo VALUES ('', '封开县', '');
INSERT INTO booktest_areainfo VALUES ('', '德庆县', '');
INSERT INTO booktest_areainfo VALUES ('', '高要市', '');
INSERT INTO booktest_areainfo VALUES ('', '四会市', '');
INSERT INTO booktest_areainfo VALUES ('', '惠州市', '');
INSERT INTO booktest_areainfo VALUES ('', '惠城区', '');
INSERT INTO booktest_areainfo VALUES ('', '惠阳区', '');
INSERT INTO booktest_areainfo VALUES ('', '博罗县', '');
INSERT INTO booktest_areainfo VALUES ('', '惠东县', '');
INSERT INTO booktest_areainfo VALUES ('', '龙门县', '');
INSERT INTO booktest_areainfo VALUES ('', '梅州市', '');
INSERT INTO booktest_areainfo VALUES ('', '梅江区', '');
INSERT INTO booktest_areainfo VALUES ('', '梅县', '');
INSERT INTO booktest_areainfo VALUES ('', '大埔县', '');
INSERT INTO booktest_areainfo VALUES ('', '丰顺县', '');
INSERT INTO booktest_areainfo VALUES ('', '五华县', '');
INSERT INTO booktest_areainfo VALUES ('', '平远县', '');
INSERT INTO booktest_areainfo VALUES ('', '蕉岭县', '');
INSERT INTO booktest_areainfo VALUES ('', '兴宁市', '');
INSERT INTO booktest_areainfo VALUES ('', '汕尾市', '');
INSERT INTO booktest_areainfo VALUES ('', '城区', '');
INSERT INTO booktest_areainfo VALUES ('', '海丰县', '');
INSERT INTO booktest_areainfo VALUES ('', '陆河县', '');
INSERT INTO booktest_areainfo VALUES ('', '陆丰市', '');
INSERT INTO booktest_areainfo VALUES ('', '河源市', '');
INSERT INTO booktest_areainfo VALUES ('', '源城区', '');
INSERT INTO booktest_areainfo VALUES ('', '紫金县', '');
INSERT INTO booktest_areainfo VALUES ('', '龙川县', '');
INSERT INTO booktest_areainfo VALUES ('', '连平县', '');
INSERT INTO booktest_areainfo VALUES ('', '和平县', '');
INSERT INTO booktest_areainfo VALUES ('', '东源县', '');
INSERT INTO booktest_areainfo VALUES ('', '阳江市', '');
INSERT INTO booktest_areainfo VALUES ('', '江城区', '');
INSERT INTO booktest_areainfo VALUES ('', '阳西县', '');
INSERT INTO booktest_areainfo VALUES ('', '阳东县', '');
INSERT INTO booktest_areainfo VALUES ('', '阳春市', '');
INSERT INTO booktest_areainfo VALUES ('', '清远市', '');
INSERT INTO booktest_areainfo VALUES ('', '清城区', '');
INSERT INTO booktest_areainfo VALUES ('', '佛冈县', '');
INSERT INTO booktest_areainfo VALUES ('', '阳山县', '');
INSERT INTO booktest_areainfo VALUES ('', '连山壮族瑶族自治县', '');
INSERT INTO booktest_areainfo VALUES ('', '连南瑶族自治县', '');
INSERT INTO booktest_areainfo VALUES ('', '清新县', '');
INSERT INTO booktest_areainfo VALUES ('', '英德市', '');
INSERT INTO booktest_areainfo VALUES ('', '连州市', '');
INSERT INTO booktest_areainfo VALUES ('', '东莞市', '');
INSERT INTO booktest_areainfo VALUES ('', '中山市', '');
INSERT INTO booktest_areainfo VALUES ('', '潮州市', '');
INSERT INTO booktest_areainfo VALUES ('', '湘桥区', '');
INSERT INTO booktest_areainfo VALUES ('', '潮安区', '');
INSERT INTO booktest_areainfo VALUES ('', '饶平县', '');
INSERT INTO booktest_areainfo VALUES ('', '揭阳市', '');
INSERT INTO booktest_areainfo VALUES ('', '榕城区', '');
INSERT INTO booktest_areainfo VALUES ('', '揭东县', '');
INSERT INTO booktest_areainfo VALUES ('', '揭西县', '');
INSERT INTO booktest_areainfo VALUES ('', '惠来县', '');
INSERT INTO booktest_areainfo VALUES ('', '普宁市', '');
INSERT INTO booktest_areainfo VALUES ('', '云浮市', '');
INSERT INTO booktest_areainfo VALUES ('', '云城区', '');
INSERT INTO booktest_areainfo VALUES ('', '新兴县', '');
INSERT INTO booktest_areainfo VALUES ('', '郁南县', '');
INSERT INTO booktest_areainfo VALUES ('', '云安县', '');
INSERT INTO booktest_areainfo VALUES ('', '罗定市', '');
INSERT INTO booktest_areainfo VALUES ('', '湖南省', NULL);
INSERT INTO booktest_areainfo VALUES ('', '长沙市', '');
INSERT INTO booktest_areainfo VALUES ('', '芙蓉区', '');
INSERT INTO booktest_areainfo VALUES ('', '天心区', '');
INSERT INTO booktest_areainfo VALUES ('', '岳麓区', '');
INSERT INTO booktest_areainfo VALUES ('', '开福区', '');
INSERT INTO booktest_areainfo VALUES ('', '雨花区', '');
INSERT INTO booktest_areainfo VALUES ('', '长沙县', '');
INSERT INTO booktest_areainfo VALUES ('', '望城县', '');
INSERT INTO booktest_areainfo VALUES ('', '宁乡县', '');
INSERT INTO booktest_areainfo VALUES ('', '浏阳市', '');
INSERT INTO booktest_areainfo VALUES ('', '株洲市', '');
INSERT INTO booktest_areainfo VALUES ('', '荷塘区', '');
INSERT INTO booktest_areainfo VALUES ('', '芦淞区', '');
INSERT INTO booktest_areainfo VALUES ('', '石峰区', '');
INSERT INTO booktest_areainfo VALUES ('', '天元区', '');
INSERT INTO booktest_areainfo VALUES ('', '株洲县', '');
INSERT INTO booktest_areainfo VALUES ('', '攸县', '');
INSERT INTO booktest_areainfo VALUES ('', '茶陵县', '');
INSERT INTO booktest_areainfo VALUES ('', '炎陵县', '');
INSERT INTO booktest_areainfo VALUES ('', '醴陵市', '');
INSERT INTO booktest_areainfo VALUES ('', '湘潭市', '');
INSERT INTO booktest_areainfo VALUES ('', '雨湖区', '');
INSERT INTO booktest_areainfo VALUES ('', '岳塘区', '');
INSERT INTO booktest_areainfo VALUES ('', '湘潭县', '');
INSERT INTO booktest_areainfo VALUES ('', '湘乡市', '');
INSERT INTO booktest_areainfo VALUES ('', '韶山市', '');
INSERT INTO booktest_areainfo VALUES ('', '衡阳市', '');
INSERT INTO booktest_areainfo VALUES ('', '珠晖区', '');
INSERT INTO booktest_areainfo VALUES ('', '雁峰区', '');
INSERT INTO booktest_areainfo VALUES ('', '石鼓区', '');
INSERT INTO booktest_areainfo VALUES ('', '蒸湘区', '');
INSERT INTO booktest_areainfo VALUES ('', '南岳区', '');
INSERT INTO booktest_areainfo VALUES ('', '衡阳县', '');
INSERT INTO booktest_areainfo VALUES ('', '衡南县', '');
INSERT INTO booktest_areainfo VALUES ('', '衡山县', '');
INSERT INTO booktest_areainfo VALUES ('', '衡东县', '');
INSERT INTO booktest_areainfo VALUES ('', '祁东县', '');
INSERT INTO booktest_areainfo VALUES ('', '耒阳市', '');
INSERT INTO booktest_areainfo VALUES ('', '常宁市', '');
INSERT INTO booktest_areainfo VALUES ('', '邵阳市', '');
INSERT INTO booktest_areainfo VALUES ('', '双清区', '');
INSERT INTO booktest_areainfo VALUES ('', '大祥区', '');
INSERT INTO booktest_areainfo VALUES ('', '北塔区', '');
INSERT INTO booktest_areainfo VALUES ('', '邵东县', '');
INSERT INTO booktest_areainfo VALUES ('', '新邵县', '');
INSERT INTO booktest_areainfo VALUES ('', '邵阳县', '');
INSERT INTO booktest_areainfo VALUES ('', '隆回县', '');
INSERT INTO booktest_areainfo VALUES ('', '洞口县', '');
INSERT INTO booktest_areainfo VALUES ('', '绥宁县', '');
INSERT INTO booktest_areainfo VALUES ('', '新宁县', '');
INSERT INTO booktest_areainfo VALUES ('', '城步苗族自治县', '');
INSERT INTO booktest_areainfo VALUES ('', '武冈市', '');
INSERT INTO booktest_areainfo VALUES ('', '岳阳市', '');
INSERT INTO booktest_areainfo VALUES ('', '岳阳楼区', '');
INSERT INTO booktest_areainfo VALUES ('', '云溪区', '');
INSERT INTO booktest_areainfo VALUES ('', '君山区', '');
INSERT INTO booktest_areainfo VALUES ('', '岳阳县', '');
INSERT INTO booktest_areainfo VALUES ('', '华容县', '');
INSERT INTO booktest_areainfo VALUES ('', '湘阴县', '');
INSERT INTO booktest_areainfo VALUES ('', '平江县', '');
INSERT INTO booktest_areainfo VALUES ('', '汨罗市', '');
INSERT INTO booktest_areainfo VALUES ('', '临湘市', '');
INSERT INTO booktest_areainfo VALUES ('', '常德市', '');
INSERT INTO booktest_areainfo VALUES ('', '武陵区', '');
INSERT INTO booktest_areainfo VALUES ('', '鼎城区', '');
INSERT INTO booktest_areainfo VALUES ('', '安乡县', '');
INSERT INTO booktest_areainfo VALUES ('', '汉寿县', '');
INSERT INTO booktest_areainfo VALUES ('', '澧县', '');
INSERT INTO booktest_areainfo VALUES ('', '临澧县', '');
INSERT INTO booktest_areainfo VALUES ('', '桃源县', '');
INSERT INTO booktest_areainfo VALUES ('', '石门县', '');
INSERT INTO booktest_areainfo VALUES ('', '津市市', '');
INSERT INTO booktest_areainfo VALUES ('', '张家界市', '');
INSERT INTO booktest_areainfo VALUES ('', '永定区', '');
INSERT INTO booktest_areainfo VALUES ('', '武陵源区', '');
INSERT INTO booktest_areainfo VALUES ('', '慈利县', '');
INSERT INTO booktest_areainfo VALUES ('', '桑植县', '');
INSERT INTO booktest_areainfo VALUES ('', '益阳市', '');
INSERT INTO booktest_areainfo VALUES ('', '资阳区', '');
INSERT INTO booktest_areainfo VALUES ('', '赫山区', '');
INSERT INTO booktest_areainfo VALUES ('', '南县', '');
INSERT INTO booktest_areainfo VALUES ('', '桃江县', '');
INSERT INTO booktest_areainfo VALUES ('', '安化县', '');
INSERT INTO booktest_areainfo VALUES ('', '沅江市', '');
INSERT INTO booktest_areainfo VALUES ('', '郴州市', '');
INSERT INTO booktest_areainfo VALUES ('', '北湖区', '');
INSERT INTO booktest_areainfo VALUES ('', '苏仙区', '');
INSERT INTO booktest_areainfo VALUES ('', '桂阳县', '');
INSERT INTO booktest_areainfo VALUES ('', '宜章县', '');
INSERT INTO booktest_areainfo VALUES ('', '永兴县', '');
INSERT INTO booktest_areainfo VALUES ('', '嘉禾县', '');
INSERT INTO booktest_areainfo VALUES ('', '临武县', '');
INSERT INTO booktest_areainfo VALUES ('', '汝城县', '');
INSERT INTO booktest_areainfo VALUES ('', '桂东县', '');
INSERT INTO booktest_areainfo VALUES ('', '安仁县', '');
INSERT INTO booktest_areainfo VALUES ('', '资兴市', '');
INSERT INTO booktest_areainfo VALUES ('', '永州市', '');
INSERT INTO booktest_areainfo VALUES ('', '零陵区', '');
INSERT INTO booktest_areainfo VALUES ('', '冷水滩区', '');
INSERT INTO booktest_areainfo VALUES ('', '祁阳县', '');
INSERT INTO booktest_areainfo VALUES ('', '东安县', '');
INSERT INTO booktest_areainfo VALUES ('', '双牌县', '');
INSERT INTO booktest_areainfo VALUES ('', '道县', '');
INSERT INTO booktest_areainfo VALUES ('', '江永县', '');
INSERT INTO booktest_areainfo VALUES ('', '宁远县', '');
INSERT INTO booktest_areainfo VALUES ('', '蓝山县', '');
INSERT INTO booktest_areainfo VALUES ('', '新田县', '');
INSERT INTO booktest_areainfo VALUES ('', '江华瑶族自治县', '');
INSERT INTO booktest_areainfo VALUES ('', '怀化市', '');
INSERT INTO booktest_areainfo VALUES ('', '鹤城区', '');
INSERT INTO booktest_areainfo VALUES ('', '中方县', '');
INSERT INTO booktest_areainfo VALUES ('', '沅陵县', '');
INSERT INTO booktest_areainfo VALUES ('', '辰溪县', '');
INSERT INTO booktest_areainfo VALUES ('', '溆浦县', '');
INSERT INTO booktest_areainfo VALUES ('', '会同县', '');
INSERT INTO booktest_areainfo VALUES ('', '麻阳苗族自治县', '');
INSERT INTO booktest_areainfo VALUES ('', '新晃侗族自治县', '');
INSERT INTO booktest_areainfo VALUES ('', '芷江侗族自治县', '');
INSERT INTO booktest_areainfo VALUES ('', '靖州苗族侗族自治县', '');
INSERT INTO booktest_areainfo VALUES ('', '通道侗族自治县', '');
INSERT INTO booktest_areainfo VALUES ('', '洪江市', '');
INSERT INTO booktest_areainfo VALUES ('', '娄底市', '');
INSERT INTO booktest_areainfo VALUES ('', '娄星区', '');
INSERT INTO booktest_areainfo VALUES ('', '双峰县', '');
INSERT INTO booktest_areainfo VALUES ('', '新化县', '');
INSERT INTO booktest_areainfo VALUES ('', '冷水江市', '');
INSERT INTO booktest_areainfo VALUES ('', '涟源市', '');
INSERT INTO booktest_areainfo VALUES ('', '湘西土家族苗族自治州', '');
INSERT INTO booktest_areainfo VALUES ('', '吉首市', '');
INSERT INTO booktest_areainfo VALUES ('', '泸溪县', '');
INSERT INTO booktest_areainfo VALUES ('', '凤凰县', '');
INSERT INTO booktest_areainfo VALUES ('', '花垣县', '');
INSERT INTO booktest_areainfo VALUES ('', '保靖县', '');
INSERT INTO booktest_areainfo VALUES ('', '古丈县', '');
INSERT INTO booktest_areainfo VALUES ('', '永顺县', '');
INSERT INTO booktest_areainfo VALUES ('', '龙山县', '');

areas.sql

source areas.sql

打开booktest/views.py文件,定义视图area。

from booktest.models import AreaInfo
...
#查询广州市的信息
def area(request):
area = AreaInfo.objects.get(pk=440100)
return render(request, 'booktest/area.html', {'area': area})

打开booktest/urls.py文件,新建一条url。

urlpatterns = [
...
url(r'^area/$', views.area),
]

在templates/booktest目录下,新建area.html文件。

<html>
<head>
<title>地区</title>
</head>
<body>
当前地区:{{area.atitle}}
<hr/>
上级地区:{{area.aParent.atitle}}
<hr/>
下级地区:
<ul>
{%for a in area.areainfo_set.all%}
<li>{{a.atitle}}</li>
{%endfor%}
</ul>
</body>
</html>

运行服务器。

python manage.py runserver

在浏览器中输出效果如下图。

2. 模型类的属性

属性objects:管理器,是models.Manager类型的对象,用于与数据库进行交互。

当没有为模型类定义管理器时,Django会为每一个模型类生成一个名为objects的管理器,自定义管理器后,Django不再生成默认管理器objects。

为模型类BookInfo定义管理器books语法如下:

class BookInfo(models.Model):
...
books = models.Manager()

2.1 管理器Manager

管理器是Django的模型进行数据库操作的接口,Django应用的每个模型类都拥有至少一个管理器。Django支持自定义管理器类,继承自models.Manager。

自定义管理器类主要用于两种情况:

  • 1.修改原始查询集,重写all()方法
  • 2.向管理器类中添加额外的方法,如向数据库中插入数据。

1.修改原始查询集,重写all()方法。

a)打开booktest/models.py文件,定义类BookInfoManager

#图书管理器
class BookInfoManager(models.Manager):
def all(self):
#默认查询未删除的图书信息
#调用父类的成员语法为:super().方法名
return super().all().filter(isDelete=False)

b)在模型类BookInfo中定义管理器

class BookInfo(models.Model):
...
books = BookInfoManager()

2.在管理器类中定义创建对象的方法

对模型类对应的数据表进行操作时,推荐将这些操作数据表的方法封装起来,放到模型管理器类中。

a)打开booktest/models.py文件,定义方法create。

class BookInfoManager(models.Manager):
...
#创建模型类,接收参数为属性赋值
def create_book(self, title, pub_date):
#创建模型类对象self.model可以获得模型类
book = self.model()
book.btitle = title
book.bpub_date = pub_date
book.bread=0
book.bcommet=0
book.isDelete = False
# 将数据插入进数据表
book.save()
return book

b)为模型类BookInfo定义管理器books语法如下:

class BookInfo(models.Model):
...
books = BookInfoManager()

c)调用语法如下:

调用:book=BookInfo.books.create_book("abc",date(1980,1,1))

2.2 元选项

在模型类中定义类Meta,用于设置元信息,如使用db_table自定义表的名字。

数据表的默认名称为:

<app_name>_<model_name>
例:
booktest_bookinfo

例:指定BookInfo模型类生成的数据表名为bookinfo。

在BookInfo模型类中添加如下内容,代码如下:

#定义图书模型类BookInfo
class BookInfo(models.Model):
... #定义元选项
class Meta:
db_table='bookinfo' #指定BookInfo生成的数据表名为bookinfo

Django框架(七):模型(三) 关联、模型类的属性的更多相关文章

  1. WEB框架-Django框架学习(二)- 模型层

    今日份整理为模型层 1.ORM简介 MVC或者MVC框架中包括一个重要的部分,就是ORM,它实现了数据模型与数据库的解耦,即数据模型的设计不需要依赖于特定的数据库,通过简单的配置就可以轻松更换数据库, ...

  2. Django框架基础知识08-表关联对象及多表查询

    1.自定义主键字段的创建 AutoFiled(pirmary_key=True) # 一般不会自定义,int类型,自增长 一般不自定义主键. 2.order_by asc desc from djan ...

  3. python+Django框架运用(三)

    Django模型 模式指的是根据数据库中数据表的结构来创建出来的class,每一张表到Python中就是一个 class,表中的每一个列,到Python中就是class的一个属性. 在模型中可以完成对 ...

  4. Python笔记(七):字典、类、属性、对象实例、继承

    (一)  简单说明 字典是Python的内置数据结构,将数据与键关联(例如:姓名:张三,姓名是键,张三就是数据).例如:下面这个就是一个字典 {'姓名': '张三', '出生日期': '2899-08 ...

  5. Django框架 (七) Django ORM模型

    ORM简介 查询数据层次图解:如果操作mysql,ORM是在pymysq之上又进行了一层封装

  6. django学习笔记(三)模型

    1.创建一个django app: python manage.py startapp books 2.validate 命令检查你的模型的语法和逻辑是否正确.一旦你觉得你的模型可能有问题,运行 py ...

  7. Django框架之第八篇(模型层补充)--数据库的查询与优化:only/defer,select_related与prefetch_related,事务

    在设置外键字段时需要注意: 当你使用django2.x的版本时候,在建立外键关系时,需要你手动添加几个关键点参数 models.cascade #设置级联删除 db_constraints 数据库查询 ...

  8. Python Django框架笔记(三):django工作方式简单说明和创建用户界面

    (一)  说明 简单说明下django的工作方式,并举2个例子. (二)  Django工作方式 假定我们有下面这些文件 ,这里在前2篇的基础上增加了 templates目录(存放html文件) 和s ...

  9. Django框架之第三篇模板语法(重要!!!)

    一.什么是模板? 只要是在html里面有模板语法就不是html文件了,这样的文件就叫做模板. 二.模板语法分类 一.模板语法之变量:语法为 {{ }}: 在 Django 模板中遍历复杂数据结构的关键 ...

随机推荐

  1. 使用Kickstart+pxe自动化安装部署无人值守的linux服务器

    Kickstart+pxe Kickstart无人职守安装RHEL5过程分享(详细图解版) 启动应用有:httpd.dhcpd.named.xinetd 无人职守自动批量安装linux系统超详细 参考 ...

  2. 三十九、SAP中多语言的处理

    一.点击菜单翻译 二.选择目标语言 三.输入需要翻译的内容,并保存 四.我们切换到英语模式登录 五.查看我们的代码 六.输出结果如下,多语言特征就显示了

  3. SQL 、LINQ日前比较

      using Newtonsoft.Json; using Newtonsoft.Json.Linq; using System; using System.Collections.Generic; ...

  4. LCT(2)

    LCT(2) 关于 LCT 的基本操作和代码实现见 (1) . 5. LCT的应用 5.0 LCT 裸题 就是LCT的基本操作模板题,常出现于早年省选.不讨论. 5.1 LCT维护子树信息 很多时候, ...

  5. Spring-ResolvableType可解决的数据类型

    ResolvableType,可解决的数据类型.它为java语言中的所有类型提供了相同的数据结构,其内部封装了一个java.lang.reflect.Type类型的对象. 在讲解这个数据结构之前,首先 ...

  6. SpringMVC: JSON

    SpringMVC:JSON讲解 什么是JSON? JSON(JavaScript Object Notation, JS 对象标记) 是一种轻量级的数据交换格式,目前使用特别广泛. 采用完全独立于编 ...

  7. HTTP TCP UDP ICMP IP ARP 协议详解(10.15 第二十一天)

    ARP协议 ARP(Address Resolution Protocol)协议 地址解析协议 把网络层的IP地址翻译成在数据链路层寻址的48位硬件地址(MAC地址) 在OSI模型中ARP协议属于链路 ...

  8. UVA - 11093 Just Finish it up(环形跑道)(模拟)

    题意:环形跑道上有n(n <= 100000)个加油站,编号为1~n.第i个加油站可以加油pi加仑.从加油站i开到下一站需要qi加仑汽油.你可以选择一个加油站作为起点,起始油箱为空(但可以立即加 ...

  9. comm

    comm [- 123 ] file1 file2 说明:该命令是对两个已经排好序的文件进行比较.其中file1和file2是已排序的文件.comm读取这两个文件,然后生成三列输出:仅在file1中出 ...

  10. Community Cloud零基础学习(三)Partner Account

    本篇参考:http://salesforce.vidyard.com/watch/bLE3QNRSej2iasw9vvc6Tk http://salesforce.vidyard.com/watch/ ...