1.django的生命周期:

  url -> 路由系统 -> 视图函数(获取模版 + 数据 =>渲染) -> 返回字符串

2.路由系统:

    /index/          ->函数或类.as_view()

  /detail/(\d)        ->函数(参数)或 类.as_view()(参数)

  /detail/(?P<nid>\d+)     ->函数(参数)或 类.as_view()(参数)

  /detail/           -> include('app01.urls')

  /detail/  name='a1'     -> include('app01.urls')

视图views.py

from django.shortcuts imoport reverse

# 获取原路径
reverse('a1')

模版

{%   url 'a1'   %}

3. 视图

FBV:函数  path(r'index',views.index)

  def index(request,*args,**kwargs):

    pass

CBV:类        path(r'index',views.Index.as_view())

  class Index(views.view):

    pass

获取用户的数据:

   request.GET.get(xxx)

  request.POST.get(xxx)

  reqest.FILES.get(xxxx)

  obj = request.FILES.get('xxx')

  f = open('simple01.txt','wb')

  for chunk in obj.chunks():

    f.write(chunk)

  f.close()

  # checkbox的值的获取

  request.GET.getlist('xxx'

给用户返回数据的形式:

render(request,'xxx.html',{arg0:1234,arg1:[1,2,3,4]})
HtppResponse(字符串)
redirect('URL')

4.模版语言

render(request, "模板的文件的路径", {'obj': 1234, 'k1': [1,2,3,4],"k2": {'name': '张扬','age': 73}})
<html>
<body>
<h1>{{ obj }}</h1>
<h1>{{ k1.1 }}</h1>
<h1>{{ k2.name }}</h1>
{% for v in k2.values %}
<h1>{{ v }}</h1>
{% endfor %}
</body>
</html>

5.ORM

a. 创建类和字段

class UserInfo(models.Model):
name = models.CharField(max_length=32)
age = models.IntgerField()

终端执行:

python3 manage.py makemerigations
python3 manage.py merigate

注意:setting.py文件中,是否INSTALL_APPS是否注册app?

b. 操作

增 以下两种方式都可以

models.UserInfo.objects.create(name='xm01',age=23)

obj = models.UserInfo(name='xm02',age=34)
obj.save()

models.UserInfo.objects.filter(name='xm01').delete()

models.UserInfo.objects.filter('xm02').update(name='xm01')
user_info = {'name':'xm03','age':34}
models.UserInfo.object.filter(id__gt=0).update(**user_info)

# 查询全部 返回QuerySet对象
models.UserInfo.objects.all()
# 条件查询
models.UserInfo.objects.filter(name='xm01')
# and的使用
models.UserInfo.objects.filter(name='xm01',age=23)
# 查询某些字段
models.UserInfo.objects.all().values('name') # 获取一个对象,如果不存在则报错
models.UserInfo.objects.get(id=1)
或者 如果存在则返回对象,否则返回None
obj = models.UserInfo.objects.filter(id=1).first()

外键

# caption 1:普通用户  2:VIP用户   3:游客
class UserType(models.Model):
caption = models.CharFileld(max_length=32) class User(models.Model):
age = models.IntegerField()
name = models.CharField(max_length=64)
# 约束
user_type = models.ForeignKey(to='UserType' to_field='id')

6.Ajax

基本使用

<script src="../static/jquery-1.12.4.js"></script>
<script>
$.ajax({
url:'/orm.html',
data: {'account': 'xm02','pwd':''},
dataType: 'json',
traditional: true,
success: function (data) { }
})
</script>

dataType:返回的参数格式为json数据类型

traditoinal: 参数中包含数组的时候,将此参数设置为true,这样数据才会被传递,当遇到参数为字典的时候,需要通过JSON.stringify(dict)

7.一对多

外键

from django.db import models

class UserGroup(models.Model):
name = models.CharField(max_length=32) class UserInfo(models.Model):
username = models.CharField(max_length=32)
pwd = models.CharField(max_length=32)
gender = models.CharField(max_length=4)
group_type = models.ForeignKey(UserGroup,to_field='id',on_delete=models.CASCADE)

用法:

# 创建数据
# models.UserGroup.objects.create(name='python')
# models.UserGroup.objects.create(name='Ruby')
# obj = models.UserGroup(name='Object-C')
# obj.save() models.UserInfo.objects.create(username='xm01',gender='',pwd='',group_type_id=1) for row in models.UserInfo.objects.all():
print(row.username,row.pwd,row.gender,row.group_type,sep='\t')
print(row.group_type.name) obj = models.UserInfo.objects.filter(group_type_id=1)
print(obj)
obj = models.UserInfo.objects.filter(id__gt=1).values('username','gender','group_type__name')
print(obj)
for row in obj:
print(row['username'],row['gender'],row['group_type__name'],sep='\t')

# 输出 
# xm01 123456 0 UserGroup object (1)
# python
# <QuerySet [<UserInfo: UserInfo object (1)>]>
# <QuerySet [{'username': 'xm02', 'gender': '1', 'group_type__name': 'Ruby'}, {'username': 'xm03', 'gender': '0', 'group_type__name': 'Object-C'}]
# xm02    1    Ruby
# xm03    0    Object-C

UserInfo中的group_type为UserGroup类型的对象,而且外键关联,默认生成 xxx_id字段作为新关联其他模型的字段,如果获取外表的字段,需要通过xxx__op可以获取外表的op字段值

8.多对多

a.自定义关系表

from django.db import models

class Host(models.Model):
nid = 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() class Application(models.Model):
name = models.CharField(max_length=32)
h = models.ManyToManyField(Host)

此时django会自动生成第三张表,表名和表结构如下:

调用方法如下

# obj = Application.objects.filter(id=1).first()
# obj.h.add(1)
# obj.h.add(2,3)
# obj.h.add(*[1,2,3]) # obj.h.remove(1)
# obj.h.clear() # obj.h.set([2]) # 返回Host类型的QuerySet对象
qset = obj.h.all()
for row in qset:
print(row.hostname,row.ip,row.port,sep='\t')

django基础篇03-阶段总结的更多相关文章

  1. iOS系列 基础篇 03 探究应用生命周期

    iOS系列 基础篇 03 探究应用生命周期 目录: 1. 非运行状态 - 应用启动场景 2. 点击Home键 - 应用退出场景 3. 挂起重新运行场景 4. 内存清除 - 应用终止场景 5. 结尾 本 ...

  2. 01: Django基础篇

    目录:Django其他篇 01:Django基础篇 02:Django进阶篇 03:Django数据库操作--->Model 04: Form 验证用户数据 & 生成html 05:Mo ...

  3. Java多线程系列--“基础篇”03之 Thread中start()和run()的区别

    概要 Thread类包含start()和run()方法,它们的区别是什么?本章将对此作出解答.本章内容包括:start() 和 run()的区别说明start() 和 run()的区别示例start( ...

  4. 01:django基础篇

    Django其他篇 目录: 1.1 django初探 1.2 第一个django项目 1.3 django render/redirect/HttpResponse 和 request.GET req ...

  5. python的django基础篇

    一.Django基础 Django 是用Python开发的一个免费开源的Web框架,可以用于快速搭建高性能,优雅的网站! Django的特点: 强大的数据库功能:拥有强大的数据库操作接口(QueryS ...

  6. python3之Django基础篇

    一.Django基础 Django 是用Python开发的一个免费开源的Web框架,可以用于快速搭建高性能,优雅的网站! Django的特点: 强大的数据库功能:拥有强大的数据库操作接口(QueryS ...

  7. WebBug靶场基础篇 — 03

    基础篇 6 - 16 关... 在记录之前,先说一件事 = =! 小学生真多 = =!好心提供一个靶场,玩玩就算了,他挂黑页 ?现在好了,以后这个靶场不对外啊!你高兴了?爽了吧? 都是新手过来的,好心 ...

  8. Django基础篇之数据库选择及相关操作

    在djanjo框架中我们最常用的框架分别就是mysql和sqlit了,下面我们将分别讲述一下这俩种数据库的基础必备知识 mysql 一.利用命令创建(在终端上执行) 1.首先创建一个project项目 ...

  9. Django基础篇--Models

    在Django中创建与数据库的链接并调用数据库的数据是很关键的步骤,那么怎么实现这个过程呢? 下面这篇文章简单梳理了一下创建Model层的过程和应用 模型-Models 首先需要理解什么是模型? 模型 ...

  10. Web框架django基础篇

    基本配置及学习  路由(Urls).视图(Views).模板(Template).Model(ORM). 简介 Django 是一个由 Python 写成的开放源代码的 Web 应用框架.它最初是被开 ...

随机推荐

  1. json 的简单应用

    今天做爬虫时的一点盲区 :字符串, 字典,写到同一个文件中.难以利用!比如这样的数据:str = “hi,budy. i like 52pojie!”dirt = {“陈墨”:["男&quo ...

  2. ASP.NET MVC3.0下载功能实现

    C#代码: #region 下载文件 /// <summary> /// 下载文件 /// </summary> /// <param name="url&qu ...

  3. 大数据笔记(二十九)——RDD简介、特性及常用算子

    1.什么是RDD? 最核心 (*)弹性分布式数据集,Resilent distributed DataSet (*)Spark中数据的基本抽象 (*)结合源码,查看RDD的概念 RDD属性 * Int ...

  4. Linux shell - cut命令用法(转载)

    cut  [-bn] [file] 或 cut [-c] [file]  或  cut [-df] [file] 使用说明 cut 命令从文件的每一行剪切字节.字符和字段并将这些字节.字符和字段写至标 ...

  5. nested exception is java.lang.OutOfMemoryError: PermGen space

    原因: 持久带内存溢出. 方法:在启动的catalina.sh 里加上这个配置,增加持久带的大小. JAVA_OPTS="XX:PermSize=64M-XX:MaxPermSize=128 ...

  6. 【机器学习速成宝典】模型篇05朴素贝叶斯【Naive Bayes】(Python版)

    目录 先验概率与后验概率 条件概率公式.全概率公式.贝叶斯公式 什么是朴素贝叶斯(Naive Bayes) 拉普拉斯平滑(Laplace Smoothing) 应用:遇到连续变量怎么办?(多项式分布, ...

  7. nginx中lua主动设置Content-Length

    最近发现lua调用ngx.say和ngx.print 默认返回的HTTP头是trunk模式的,通常情况下是很好的,没有什么问题:但是要提供给其他人回源的时候就有问题了,特别是我要给slice模块回源, ...

  8. 一个”.java”源文件中是否可以包含多个类(不是内部类)?有什么限制

    这个是可以的,一个“.java”源文件里面可以包含多个类,但是只允许有一个public类,并且类名必须和文件名一致. 每个编译单元只能有一个public 类.这么做的意思是,每个编译单元只能有一个公开 ...

  9. MYSQL5.7源码包编译安装

    Centos下用cmake编译安装MySQL 5.7安装依赖包yum -y install gcc gcc-c++ ncurses ncurses-devel cmake下载相应源码包cd /usr/ ...

  10. 读取数据库 生成Xml节点

    foreach (DataColumn v in dt.Columns) { sb.Append("sb.Append(\"<" + v.ColumnName.To ...