第二十章 Django数据库实战
第二十章 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数据库实战的更多相关文章
- python 教程 第二十章、 数据库编程
第二十章. 数据库编程 环境设置 1).安装MySQL-python http://www.lfd.uci.edu/~gohlke/pythonlibs/ MySQL-python-1.2.3.win ...
- 2017.3.14 activiti实战--第二十章--REST服务
学习资料:<Activiti实战> 第二十章 REST服务 20.1 通信协议概述 略. 20.2 REST API概述 资源分类 资源基础URI 说明 Deployments manag ...
- Python之路【第十九章】:Django 数据库对象关系映射
Django ORM基本配置 到目前为止,当我们的程序涉及到数据库相关操作时,我们一般都会这么搞: 创建数据库,设计表结构和字段 使用 MySQLdb 来连接数据库,并编写数据访问层代码 业务逻辑层去 ...
- Django高级实战 开发企业级问答网站完整
资源获取链接点击这里 Django高级实战 开发企业级问答网站 从实际需求分析开始,实现当今主流知识问答应用的功能,包括动态.文章.问答.私信.消息通知.搜索.个人中心,打造企业级知识问答网站,由此全 ...
- Django 数据库常见操作
首先要配置数据映射具体在这个连接里 https://www.cnblogs.com/Niuxingyu/p/10296143.html Django 建立数据库模型 #导包导入django数据库类 f ...
- Django高级实战 开发企业级问答网站 ✌✌
Django高级实战 开发企业级问答网站 (一个人学习或许会很枯燥,但是寻找更多志同道合的朋友一起,学习将会变得更加有意义✌✌) 从实际需求分析开始,实现当今主流知识问答应用的功能,包括动态.文章.问 ...
- Django高级实战 开发企业级问答网站✍✍✍
Django高级实战 开发企业级问答网站 1. 创建项目与app 创建项目 django-admin startproject firstsite 创建app python manage.py sta ...
- Django 数据库访问性能优化
使用标准的数据库优化技术: 在进行Django数据库访问性能优化之前,首先应该使用标准的数据库技术对其进行优化,比如给字段加索引,通过使用 django.db.models.Field.db_inde ...
- 从命令行运行django数据库操作
从命令行运行django数据库操作,报错: django.core.exceptions.ImproperlyConfigured: Requested setting DEFAULT_INDEX_T ...
随机推荐
- Spring+JTA+Atomikos+mybatis分布式事务管理
我们平时的工作中用到的Spring事务管理是管理一个数据源的.但是如果对多个数据源进行事务管理该怎么办呢?我们可以用JTA和Atomikos结合Spring来实现一个分布式事务管理的功能.了解JTA可 ...
- windows7 设定开关机事件
动记录开关机的技能你知道吗? 下面跟我来设定一下记录电脑的开关机时间吧,工作常常会用到的. 在""我的电脑"右击=>管理=>系统工具=>时间查看器=&g ...
- Django_注册全局消息
需求: 对于登录用户,无论他在哪个页面,我都需要给他全局发送一个消息提示,Django中request就是一个全局变量 那,如何做? 在models 中urser表,继承user的表类中写上一个函数, ...
- linkin大话面向对象--封装和隐藏
软件开发追求的境界:高内聚,低耦合 高内聚:尽可能把模块的内部数据,功能实现细节隐藏在模块内部独立完成,不允许外部直接干预 低耦合:仅暴露少量的方法给外部使用 到底为什么要对一个雷或者对象实现良好的封 ...
- Linux安装JDK、MySQL和Tomcat
1 依赖的安装 因为JDK.Tomcat和MySQL的安装过程中需要从网上下载部分支持包才可以继续,所以需要提前安装好依赖. yum install glibc.1686 yum -y install ...
- awk中引用shell变量执行替换的脚本
遇到问题: 现在有两个脚本,我想 将file1中的内容按file2来匹配 [root@154 home]# cat file1 3-1-1 POTV=1,POTA=0,POTP=2 1-4-76 PO ...
- bat自动打包压缩实现
1.引言 本文档的编辑目的是为了实bat脚本自动打包功能,包含包的名字命名,压缩文件内外层文件夹的名字:包含svn版本号等: 2.实现介绍 (1)获取svn号,生成批处理文件 写一个pak.bat文件 ...
- dom4j读取xml
-----记录和回顾是一个比学习更重要的环节----- 一.首先,我们需要知道xml是做什么的 1.作为软件的配置文件 2.作为数据的载体(小型的数据库) 二.xml的语法 xml文件以xml后缀名结 ...
- libGDX-wiki发布
为方便大家学习和访问,我将libgdx的wiki爬取到doku-wiki下,专门建立了以下地址.欢迎大家来共同完善. http://wiki.v5ent.com
- 从一道Python面试题说起(大神勿入)
作为一个自学Python的小白,在了解了点皮毛之后,便按捺不住自己内心的骚动,在某招聘网站上投了些简历,居然也收到了面试邀请.第二天到公司,HR废话不多讲,上来就抛出几张A4纸,"先做题吧, ...