python-day75--django项目问题详细
1.项目名要小写
2.表中字段
AutoField() 表示整形字段,建表时不用写,当整形的数字范围不够你用的时候, 你可以用 BigAutoField()字段, 表示长整形
当表内新增有关联关系的字段时,如字段设置默认值会报错,因为对应的表中没有数据,故设置 null=True
3.在视图函数中进行逻辑判断时:简单的逻辑要放在上面
4.在一张表中对多个其他表做FK,M2M时,就要使用 related_name , 否则当其他表的对象反向查询时会不知道找的是哪个字段
5.在一对一的关系中,想要修改一个对象对应的另外一张表中的数据时,首先通过这个对象找到与另外那张表的建立关系的字段,然后在另外那张表中通过这个字段值 filter 出一个QuerySet,再用update方法修改
6.一定要注释,养成习惯
7.对数据库操作时,如果是跨表操作会有性能损耗,所以在一些情况下设计表时可以进行优化 -- choices方法
- 方法一 多对一:
class UserType(models.Model):
"""
用户类型表,记录经常变动
"""
title = models.CharField(max_length=32) class UserInfo(models.Model):
"""
用户表:讲师和班主任
"""
username = models.CharField(max_length=32)
password = models.CharField(max_length=64)
email = models.CharField(max_length=32)
ut = models.ForeignKey(to="UserType")
- 方法二 choices:
class UserInfo(models.Model):
"""
用户表
"""
username = models.CharField(max_length=32)
password = models.CharField(max_length=64)
email = models.CharField(max_length=32) user_type_choices = ( #choices方法适用于记录不经常变动的
(1, '班主任'),
(2, '讲师'),
) user_type_id = models.IntegerField(choices=user_type_choices)
举例:
多对一方法: """
ID Title
1 图片
2 挨踢1024
3 段子
"""
class NewsType(models.Model):
title = models.CharField(max_length=32) """
ID Title Summary News_Type
1 t.... 科技... 2
2 t.... 科技... 1
3 t.... 科技... 2 """
class News(models.Model):
title = models.CharField(max_length=32)
summary = models.CharField(max_length=255)
news_type = models.ForeignKey(to="NewsType") # 查看所有新闻
new_list = News.objects.all()
for row in new_list:
print(row.title,row.summary,row.news_type.title)
choices方法: """
ID Title Summary News_Type
1 t.... 科技... 2
2 t.... 科技... 1
3 t.... 科技... 2 """
class News(models.Model):
title = models.CharField(max_length=32)
summary = models.CharField(max_length=255) news_type_chices = (
(1,'图片'),
(2,'挨踢1024'),
(3,'段子'),
)
news_type = models.IntegerField(choices=news_type_chices) # 查看所有新闻
new_list = News.objects.all()
for row in new_list:
print(row.title,row.summary, row.get_news_type_display() )
8. session 验证 + 装饰器 + settings 配置
settings 配置 : 在 settings.py 中 自定义 SJF = "user_info" ,注意变量名一定要大写。这样配置后 避免在修改 'user_info' 时 大量的在视图函数中修改,只要在配置文件中改一下就OK了
session 操作 :
1. 先引用 from django.conf import settings
2.设值: request.session[settings.SJF] = {'id':user.id, 'username':user.username}
3.取值: request.session[settings.SJF] 与 request.session.get(settings.SJF) 的区别, 前者取不到值会报错,而后者取不到会返回none
session 装饰器:
def auth(func):
def inner(request,*args,**kwargs):
user_info = request.session.get(settings.SJF)
if not user_info:
return redirect('/login/')
return func(request,*args,**kwargs)
return inner
9.设计表时- 属性相同归类到一张表中 ,如: 讲师 与 班主任
10. uwsgi,wsgi什么区别?
wsgi, 是web服务网关接口,是协议
uwsgi 实现协议的模块
wsgiref 实现协议的模块
11.FK关系
"""
id name
1 n1
2 n2
3 n3
""" class A:
name = xxx """
id title xx_id
1 uu1 2
2 uu2 2
"""
class B:
title = xxxx
xx = FK() # 从B表开始查
data = models.B.objects.filter(title=xxx,xx_id=1,xx__name='xxx')
data = models.B.objects.filter(**{"title":xxx,"xx_id":1,"xx__name":'xxx'})
data = models.B.objects.filter(title=xxx,xx_id=1,xx__name='xxx').values("title",'xx_id','xx__name')
data = models.B.objects.filter(title=xxx,xx_id=1,xx__name='xxx').values_list("title",'xx_id','xx__name') data = models.B.objects.all()
for item in data:
item.tile
item.xx.name # 从A表开始查
data = models.A.objects.all()
for item in data:
item.id,item.name, item.b_set.all() data = models.A.objects.filter() # 3条记录
data = models.A.objects.filter(b__id=2) #1 条记录
data = models.A.objects.filter(b__id=2).values('id','name','b__title') #1条记录 data = models.A.objects.values('id','name','b__title') #4 条记录 !!!!!注意
1 n1 None
2 n2 uu1
2 n2 uu2
3 n3 None
12、如果获取的数据不是直接可以展示的结构
延迟视图函数的数据处理,只有当前端用值的时候才进行处理,性能优化 #方式一:利用类、__iter__、yield实现
class Foo(object):
def __init__(self,data):
self.data = data def __iter__(self):
for item in self.data:
yield item def test(request):
user_list = [
{'id':1,'name':'alex','age':19},
{'id':2,'name':'eric','age':18},
]
obj = Foo(user_list)
return render(request,'test.html',{'user_list':obj}) #方式二:利用生成器函数 --只有当前端用到'user_list'的时候才执行
def test(request):
user_list = [
{'id':1,'name':'alex','age':19},
{'id':2,'name':'eric','age':18},
]
def inner(arg):
for item in arg:
yield {"id":item['id'],"name":item['name'],"age":item['age']} return render(request,'test.html',{'user_list':inner(user_list)})
python-day75--django项目问题详细的更多相关文章
- python 的django项目复制方法
python 的django项目复制方法 django_pyecharts_1修改为django_pyecharts_1_cs1.拷贝项目(确保原有项目是关闭状态下)2.粘贴项目并删除idea文件夹和 ...
- python——创建django项目全攻略(野生程序员到家养程序员的完美进化)
新建工程 我用pycharm写代码,所以一般就用pycharm创建django工程.右上角File-New Project.选择路径,修改项目名称,确定.就可以创建一个新的django工程. ...
- [Python] 建 Django 项目
Python和Django的安装见这里:http://www.runoob.com/django/django-install.html 安装 Django 之后,您现在应该已经有了可用的管理工具 d ...
- python创建Django项目
创建Django项目 关注公众号"轻松学编程"了解更多. 创建一个HelloDjango项目 GitHub地址:https://github.com/liangdongchang/ ...
- 网站开发学习Python实现-Django项目部署-介绍(6.2.1)
@ 目录 1.第一步:找源码 2.第二步:在windows中更改代码 2.第三步:同步到linux中 3.第三步:部署 4.第四步:运行 关于作者 1.第一步:找源码 从github上找一个djang ...
- 使用pycharm 运行python的django项目时报错“Quit the server with CTRL-BREAK.”
Quit the server with CTRL-BREAK.Error: [Errno 10013] 1昨晚测试时还好好的,怎么突然出现这个错误,于是GOOLE,找到个帖子说可能是端口占用了,用工 ...
- Python:Django 项目中可用的各种装备和辅助
1 Redis 数据库 2 MySQL 数据库 3 前端服务器 live-server 4 定时任务 django-crontab扩展 5 Docker 容器 --用来运行 FastDFS 分布式文件 ...
- 网站开发学习Python实现-Django项目部署-同步之前写的博客(6.2.2)
@ 目录 1.说明 2.思路 3.代码 关于作者 1.说明 之前写的博客都在csdn和博客园中 要将博客同步到自己的博客网站中 因为都是使用markdown格式书写的,所以直接爬取上传就完事 2.思路 ...
- centos部署Django项目的前提工作
从安装python到django项目的部署上线.是相当详细了,中间也没有出现什么幺蛾子.很赞!!! https://blog.csdn.net/u011798443/article/details/8 ...
- 基于Nginx和uWSGI在Ubuntu上部署Django项目
前言: 对于做Django web项目的童鞋,重要性不言而喻. 参考:https://www.cnblogs.com/alwaysInMe/p/9096565.html https://blog.cs ...
随机推荐
- LOJ121 「离线可过」动态图连通性
思路 动态图连通性的板子,可惜我不会在线算法 离线可以使用线段树分治,每个边按照存在的时间插入线段树的对应节点中,最后再dfs一下求出解即可,注意并查集按秩合并可以支持撤销操作 由于大量使用STL跑的 ...
- delimiters 插值 选项
delimiters差值选项vue默认是{{}},这个选项可以把这个差值形式进行改变,这里讲,默认插值改成${} html <div id="app"> <div ...
- Ubuntu 14.04 安装sublime
参考 How do I install Sublime Text 2/3? Ubuntu 14.04 安装sublime 通过apt-get包管理器安装sublime. sublime2.0: sud ...
- React Native组件之BackAndroid !安卓手机的物理返回键的使用
ok!在安卓手机上,当我们用物理返回键的时候,会以一次性的将程序退出来,这样是很不好的体验,所以就需要使用RN的物理返回键组件:BackAndroid,其原理也就是 分析路由,然后pop()这样! o ...
- 数据库备份出现警告:Warning: Using a password on the command line interface can be insecure. Warning: A partial dump from a server that has GTIDs will by default include the GTIDs of all transactions, even thos
1.先来看原备份数据库语句: mysqldump -h 127.0.0.1 -uroot -ppassword database > /usr/microStorage/dbbackup/cap ...
- python,函数的基本用法
一.函数 函数的概念:对功能或者动作的封装可以帮我们把一段公共的代码提取出来 语法如下 def 函数名(形参): 函数体 函数名(实参) # 函数名() def yue(): print(" ...
- 配置多个版本的jdk
引言: 由于公司有多个项目都需要我开发,而各个项目所依赖的jdk版本又不同,因此需要配置多个jdk; 配置方法: 什么也不说了,直接上图: 然后在其他需要制定Tomcat的地方直接引用JAVA_HOM ...
- SSL证书申请,如何快速通过SSL文件验证。
申请SSL证书会让我们进行验证域名,一般方式如下: 1.FTP验证 2.文件验证 3.DNS验证 这三种方式各有各的优缺点,本文解决如何在IIS的环境下通过sslforfree网站的文件验证. 域名: ...
- STL_map.修改删除
1.修改示例 int TdrSvgAttr::AttrSet_mem(bool _bAttrInStyle, string &_strAttrName, string& _strAtt ...
- IPC 之 Socket 的使用
一.概述 我们知道在开发中,即时通讯.设备间的通信都是使用 Socket 实现,那当然用它来实现进程间通信更是不成问题.Socket 即套接字,是一个对 TCP / IP协议进行封装 的编程调用接口( ...