第二十章 Django数据库实战

第一课 获取单表单数据的三种方式:

urls.py中的路由代码:

path('busniess',views.busniess),

views.py中代码:

def busniess(req):

v1=models.busniess.objects.all()

print('v1:',v1)#是对象

v2=models.busniess.objects.all().values('id','caption')

print('v2:',v2)#是字典

v3=models.busniess.objects.values_list('id','caption')

print('v3',v3)

return render(req,'busniess.html',{'v1':v1,'v2':v2,'v3':v3})

Template目录下创建busniess.html文件,代码:

<ul>

{% for i in v1 %}

<li>{{ i.id }}-{{ i.caption }}-{{ i.code }}</li>

{% endfor %}

</ul>

<ul>

{% for i in v2 %}

<li>{{ i.id }}-{{ i.caption }}</li>

{% endfor %}

</ul>

<ul>

{% for i in v3 %}

<li>{{ i.0 }}-{{ i.1 }}</li>

{% endfor %}

</ul>

浏览器访问URL:http://127.0.0.1:8000/app02/busniess

首页显示:

1-运维-aa

2-销售-bb

3-开发-cc

4-渠道-dd

1-运维

2-销售

3-开发

4-渠道

1-运维

2-销售

3-开发

4-渠道

运行输出:

v1: <QuerySet [<busniess: busniess object (1)>, ...]>

v2: <QuerySet [{'id': 1, 'caption': '运维'},...]>

v3 <QuerySet [(1, '运维'), (2, '销售'), (3, '开发'), (4, '渠道')]>

第二课 一对多跨表操作

获取一对多表单数据:

1.建立两张表,一张主键表busniess,一张参照表host,Models.py中代码:

class busniess(models.Model):

caption=models.CharField(max_length=64)

code=models.CharField(max_length=32)

class Host(models.Model):

uid=models.AutoField(primary_key=True)

hostname=models.CharField(max_length=32,db_index=True)

ip=models.GenericIPAddressField(protocol='ipv4',db_index=True)

port=models.IntegerField()

b=models.ForeignKey(to='busniess',to_field='id',on_delete=models.CASCADE)

2.在命令行下执行创建完毕:

python manage.py makemigrations

python manage.py migrate

3.在两张表中自定义一些数据。

4.在urls.py中加入路径:path('host',views.host),

5.在views.py中代码:

def host(req):

v1=models.Host.objects.filter(uid__gt=0)

for row in v1:

print(row.uid,row.hostname,row.ip,row.port,row.b_id,row.b)

return HttpResponse('host')

6.浏览器访问:http://127.0.0.1:8000/app02/host 触发函数

7.后台输出:

1 c1.com 1.1.1.1 9900 1 busniess object (1)

2 c2.com 1.1.1.2 8800 1 busniess object (1)

3 c3.com 1.1.1.3 7700 2 busniess object (2)

8.修改5中代码:

def host(req):

v1=models.Host.objects.filter(uid__gt=0)

for row in v1:

print(row.uid,row.hostname,row.ip,row.port,row.b_id,row.b.id,row.b.caption)

return HttpResponse('host')

9.后台输出:

1 c1.com 1.1.1.1 9900 1 1 运维

2 c2.com 1.1.1.2 8800 1 1 运维

3 c3.com 1.1.1.3 7700 2 2 销售

10. <td>{{ forloop.counter}}</td> 可用于添加序号

第三课 创建多对多以及增加示例

1.创建多对多:

方式一:自定义关系表

class Host(models.Model):

uid=models.AutoField(primary_key=True)

hostname=models.CharField(max_length=32,db_index=True)

ip=models.GenericIPAddressField(protocol='ipv4',db_index=True)

port=models.IntegerField()

b=models.ForeignKey(to='busniess',to_field='id',on_delete=models.CASCADE)

class Application(models.Model):

name=models.CharField(max_length=32)

class HostToApplication(models.Model):

hobj=models.ForeignKey(to='Host',to_field='uid',on_delete=models.CASCADE)

aobj=models.ForeignKey(to='Application',to_field='id',on_delete=models.CASCADE)

方式二:自动创建关系表:

class Host(models.Model):

uid=models.AutoField(primary_key=True)

hostname=models.CharField(max_length=32,db_index=True)

ip=models.GenericIPAddressField(protocol='ipv4',db_index=True)

port=models.IntegerField()

b=models.ForeignKey(to='busniess',to_field='id',on_delete=models.CASCADE)

class Application(models.Model):

name=models.CharField(max_length=32)

r=models.ManyToManyField('Host')

#无法直接对第三张表进行操作 obj.r.all()

第二十章 Django数据库实战第一课 获取单表单数据的三种方式:urls.py中的路由代码:path('busniess',views.busniess),views.py中代码:def busniess(req):v1=models.busniess.objects.all()print('v1:',v1)#是对象v2=models.busniess.objects.all().values('id','caption')print('v2:',v2)#是字典v3=models.busniess.objects.values_list('id','caption')print('v3',v3)return render(req,'busniess.html',{'v1':v1,'v2':v2,'v3':v3})Template目录下创建busniess.html文件,代码:<ul>{% for i in v1 %}<li>{{ i.id }}-{{ i.caption }}-{{ i.code }}</li>{% endfor %}</ul><ul>{% for i in v2 %}<li>{{ i.id }}-{{ i.caption }}</li>{% endfor %}</ul><ul>{% for i in v3 %}<li>{{ i.0 }}-{{ i.1 }}</li>{% endfor %}</ul>浏览器访问URL:http://127.0.0.1:8000/app02/busniess首页显示:1-运维-aa2-销售-bb3-开发-cc4-渠道-dd1-运维2-销售3-开发4-渠道1-运维2-销售3-开发4-渠道运行输出:v1: <QuerySet [<busniess: busniess object (1)>, ...]>v2: <QuerySet [{'id': 1, 'caption': '运维'},...]>v3 <QuerySet [(1, '运维'), (2, '销售'), (3, '开发'), (4, '渠道')]>第二课 一对多跨表操作获取一对多表单数据:1.建立两张表,一张主键表busniess,一张参照表host,Models.py中代码:class busniess(models.Model):caption=models.CharField(max_length=64)code=models.CharField(max_length=32)class Host(models.Model):uid=models.AutoField(primary_key=True)hostname=models.CharField(max_length=32,db_index=True)ip=models.GenericIPAddressField(protocol='ipv4',db_index=True)port=models.IntegerField()b=models.ForeignKey(to='busniess',to_field='id',on_delete=models.CASCADE)2.在命令行下执行创建完毕:python manage.py makemigrationspython manage.py migrate3.在两张表中自定义一些数据。4.在urls.py中加入路径:path('host',views.host),5.在views.py中代码:def host(req):v1=models.Host.objects.filter(uid__gt=0)for row in v1:print(row.uid,row.hostname,row.ip,row.port,row.b_id,row.b)return HttpResponse('host')6.浏览器访问:http://127.0.0.1:8000/app02/host 触发函数7.后台输出:1 c1.com 1.1.1.1 9900 1 busniess object (1)2 c2.com 1.1.1.2 8800 1 busniess object (1)3 c3.com 1.1.1.3 7700 2 busniess object (2)8.修改5中代码:def host(req):v1=models.Host.objects.filter(uid__gt=0)for row in v1:print(row.uid,row.hostname,row.ip,row.port,row.b_id,row.b.id,row.b.caption)return HttpResponse('host')9.后台输出:1 c1.com 1.1.1.1 9900 1 1 运维2 c2.com 1.1.1.2 8800 1 1 运维3 c3.com 1.1.1.3 7700 2 2 销售10. <td>{{ forloop.counter}}</td> 可用于添加序号
第三课 创建多对多以及增加示例1.创建多对多:方式一:自定义关系表class Host(models.Model):uid=models.AutoField(primary_key=True)hostname=models.CharField(max_length=32,db_index=True)ip=models.GenericIPAddressField(protocol='ipv4',db_index=True)port=models.IntegerField()b=models.ForeignKey(to='busniess',to_field='id',on_delete=models.CASCADE)class Application(models.Model):name=models.CharField(max_length=32)class HostToApplication(models.Model):hobj=models.ForeignKey(to='Host',to_field='uid',on_delete=models.CASCADE)aobj=models.ForeignKey(to='Application',to_field='id',on_delete=models.CASCADE)方式二:自动创建关系表:class Host(models.Model):uid=models.AutoField(primary_key=True)hostname=models.CharField(max_length=32,db_index=True)ip=models.GenericIPAddressField(protocol='ipv4',db_index=True)port=models.IntegerField()b=models.ForeignKey(to='busniess',to_field='id',on_delete=models.CASCADE)class Application(models.Model):name=models.CharField(max_length=32)r=models.ManyToManyField('Host')#无法直接对第三张表进行操作 obj.r.all()

第二十章 Django数据库实战的更多相关文章

  1. python 教程 第二十章、 数据库编程

    第二十章. 数据库编程 环境设置 1).安装MySQL-python http://www.lfd.uci.edu/~gohlke/pythonlibs/ MySQL-python-1.2.3.win ...

  2. 2017.3.14 activiti实战--第二十章--REST服务

    学习资料:<Activiti实战> 第二十章 REST服务 20.1 通信协议概述 略. 20.2 REST API概述 资源分类 资源基础URI 说明 Deployments manag ...

  3. Python之路【第十九章】:Django 数据库对象关系映射

    Django ORM基本配置 到目前为止,当我们的程序涉及到数据库相关操作时,我们一般都会这么搞: 创建数据库,设计表结构和字段 使用 MySQLdb 来连接数据库,并编写数据访问层代码 业务逻辑层去 ...

  4. Django高级实战 开发企业级问答网站完整

    资源获取链接点击这里 Django高级实战 开发企业级问答网站 从实际需求分析开始,实现当今主流知识问答应用的功能,包括动态.文章.问答.私信.消息通知.搜索.个人中心,打造企业级知识问答网站,由此全 ...

  5. Django 数据库常见操作

    首先要配置数据映射具体在这个连接里 https://www.cnblogs.com/Niuxingyu/p/10296143.html Django 建立数据库模型 #导包导入django数据库类 f ...

  6. Django高级实战 开发企业级问答网站 ✌✌

    Django高级实战 开发企业级问答网站 (一个人学习或许会很枯燥,但是寻找更多志同道合的朋友一起,学习将会变得更加有意义✌✌) 从实际需求分析开始,实现当今主流知识问答应用的功能,包括动态.文章.问 ...

  7. Django高级实战 开发企业级问答网站✍✍✍

    Django高级实战 开发企业级问答网站 1. 创建项目与app 创建项目 django-admin startproject firstsite 创建app python manage.py sta ...

  8. Django 数据库访问性能优化

    使用标准的数据库优化技术: 在进行Django数据库访问性能优化之前,首先应该使用标准的数据库技术对其进行优化,比如给字段加索引,通过使用 django.db.models.Field.db_inde ...

  9. 从命令行运行django数据库操作

    从命令行运行django数据库操作,报错: django.core.exceptions.ImproperlyConfigured: Requested setting DEFAULT_INDEX_T ...

随机推荐

  1. lambda高级进阶--表达式参数

    1,现在我们封装一个方法,来提供一个比较器,显然比较器是拥有两个参数的--用来比较的两个值. public class Linkin { public static String[] sort(Str ...

  2. nodejs爬虫笔记(三)---爬取YouTube网站上的视频信息

    思路:通过笔记(二)中代理的设置,已经可以对YouTube的信息进行爬取了,这几天想着爬取网站下的视频信息.通过分析YouTube,发现可以从订阅号入手,先选择几个订阅号,然后爬取订阅号里面的视频分类 ...

  3. ubuntu网桥设置

    什么是桥接? 桥接(Bridging),是指依据OSI网络模型的链路层的地址,对网络数据包进行转发的过程,工作在OSI的第二层.一般的交换机,网桥就有桥接作用. 一般的交换机,网桥就有桥接作用.就交换 ...

  4. Android 初了解

    1.1G-4G 1G 大哥大  语音通话 2G 小灵通  采用GSM,美国的一个军方标准,后来被民用了. 可以发短信了,上网的网址不是www,是wap.baidu.com 3G 可以上网了,直接用ww ...

  5. 动态库Link error 一种可能

    一般出现link error都是链接时找不到对应函数. 前些天出现这种错误,我反复地检查,都发现动态库里明确的是有对应函数的. 代码里有这样一句#pragma comment(lib,"li ...

  6. form表单中get和post两种提交方式的区别

    一.form表单中get和post两种提交方式的区别? 1.get提交表单中的内容在链接处是可见的.post不可见 2.post相比于get是安全的 3.post不收限制大小,get有限制大小(黑马视 ...

  7. 策略模式(Strategy Method)

    策略模式可以看做“可插入式算法(Pluggable)”,将子类各自的行为和公共的逻辑分离开来,将子类的行为抽象为算法插入到公共的逻辑中,这样替换子类的行为也不会对公共逻辑产生影响,也不会影响到调用类的 ...

  8. BZOJ 1192: [HNOI2006]鬼谷子的钱袋 [娱乐]

    题意: n个数分组,使得小于n的每个数都能表示出来,最少几组 就是“最优集合”的超级弱化版.....每次+=now+1 然后一个貌似科学的方法是n二进制拆分 #include <iostream ...

  9. POJ置换群入门[3/3]

    POJ 3270 Cow Sorting 题意: 一个序列变为升序,操作为交换两个元素,代价为两元素之和,求最小代价 题解: 看了黑书... 首先循环因子分解 一个循环完成的最小代价要么是循环中最小元 ...

  10. jquery参考手册

    开始使用 jQueryjQuery 本身只有一个 js 文件,所以,要使用它,就和使用其它的 js 文件一样,直接将它引入就可以使用了. <script type="text/java ...