0
点赞
收藏
分享

微信扫一扫

Django框架的第三次邂逅

伊人幽梦 2022-02-19 阅读 44

文章目录

Django框架的第三次邂逅

Django orm中创建表关系

知识回顾:

orm创建表:

from django.db import models

# 创建表关系  先将基表创建出来,然后再添加外键字段
class Book(models.Model):
    title = models.CharField(max_length=32)
    price = models.DecimalField(max_digits=8,decimal_places=2)
    # max_digits 最大位数  decimal_places 小数点后位数
    publish = models.ForeignKey(to='Publish') 
    '''
    orm中 默认就是与Publish表的主键字段做外键关联
  	如果字段对应的是ForeignKey 那么orm会自动在字段后面加_id
    ''' 
    
    '''
    多对多关系 外键字段可以建在任一方,但推荐建在查询频率较高的一方
    '''
    authors = models.ManyToManyField(to='Author')
    '''
    authors 是一个虚拟字段 作用是用来告诉orm 让orm自动创建第三张多对多关系表
    '''
    
# 出版社表
class Publish(models.Model):
    name = models.CharField(max_length=32)
    addr = models.CharField(max_length=32)
   
    
# 作者表    
class Author(models.Model):
    name = models.CharField(max_length=32)
    age = models.IntegerField()
    '''
    一对一关系 外键字段建在任一一方都可以 但是推荐建在查询频率较高的表中
    '''
    author_detail = models.OneToOneField(to='AuthorDetail')
    '''
    OnetoOneField也会自动给字段加上_id后缀
    '''
  
# 作者详情表
class AuthorDetail(models.Model):
    phone = models.BigIntegerField()  # 或者使用字符类型
    addr = models.CharField(max_length=32)
    

总结:
    orm中定义三种关系
    	publish = models.ForeignKey(to='Publish')  # 默认就是与出版社表的主键字段做外键关联
        authors = models.ManyToManyField(to='Author') # 多对多
        author_detail = models.OneToOneField(to='AuthorDetail')  # 一对一
        
        ForeignKey
		OneToOneField
			会自动在字段后面加_id后缀
        
补充:
    1. 在Django1.x版本中外键默认都是级联更新删除的
    2. 多对多的表关系可以有好几种创建方式 这里暂且先介绍一种
    3. 针对外键字段里面还有其他参数,详情请百度 

Django请求生命周期

在这里插入图片描述

整体流程说明:

路由层

路由匹配介绍

# 路由匹配
url(r'test',views.test),
url(r'testadd',views.testadd)

url方法的第一个参数是正则表达式
	只有第一个参数正则表达式能够匹配到内容,name就会立刻停止匹配,直接执行对应的视图函数
    
在输入url的时候会默认添加斜杆
	django内部会自动做到重定向
    一次匹配不成功,url后面会添加斜杠再来一次
    
# 取消自动加斜杠  settings.py文件中
	APPEND_SLASH = False/True	# 默认是True
    
urlpatterns = [
    url(r'^admin/', admin.site.urls),
    # 首页
    url(r'^$',views.home),
    # 路由匹配
    url(r'^test/$',views.test),
    url(r'^testadd/$',views.testadd),
]

无名分组与有名分组

分组:就是给某一段正则表达式用小括号扩起来
无名分组就是将括号内正则表达式匹配到的内容当作位置参数传递给后面的视图函数
	url(r'^test/(\d+)/',views.test)
	def test(request,xx):
        print(xx)
        return HttpResponse('test')
    
    
有名分组就是将括号内正则表达式匹配到的内容当作关键字参数传递给后面的视图函数
	url(r'^testadd/(?P<year>\d+)',views.testadd)
    def testadd(request,year):
    	print(year)
   		return HttpResponse('testadd')
    
 注意:
    无名分组和有名分组在django中不能混合使用 但是同一个分组可以使用n多次

反向解析

  • 指通过一些方法得到一个结果, 该结果可以直接访问对应url触发视图函数
1. 先给路由与视图函数起一个别名
	url(r'^func/', views.fun, name='ooo')
2. 反向解析
	1. 后端反向解析
    	from django.shortcuts import reverse
        reverse('ooo')
    2. 前端反向解析
    	<a href="{% url 'ooo' %}">点我</a>
举报

相关推荐

第三次作业

RHCSA:第三次

RHCSA第三次

HCIP IOT第三次

第三次周测

第三次HTML笔记

Ansible第三次作业

第三次Java作业

第三次Pr笔记

0 条评论