zoukankan      html  css  js  c++  java
  • Python正课112 —— Django 进阶2

    本文内容皆为作者原创,如需转载,请注明出处:https://www.cnblogs.com/xuexianqi/p/12968416.html

    1.数据的查,改,删

    # 先讲数据库中的数据全部展示到前端 然后给每一个数据两个按钮 一个编辑一个删除
    
    # 查看
    def userlist(request):
        # 查询出用户表里面所有的数据
        # 方式1
        # data = models.User.objects.filter()
        # print(data)
        # 方式2
        user_queryset = models.User.objects.all()
        # return render(request,'userlist.html',{'user_queryset':user_queryset})
        return render(request,'userlist.html',locals())
    
    # 编辑功能
    	# 点击编辑按钮朝后端发送编辑数据的请求
      """
      如何告诉后端用户想要编辑哪条数据?
      	将编辑按钮所在的那一行数据的主键值发送给后端
      	利用url问号后面携带参数的方式
      	
      	{% for user_obj in user_queryset %}
                            <tr>
                                <td>{{ user_obj.id }}</td>
                                <td>{{ user_obj.username }}</td>
                                <td>{{ user_obj.password }}</td>
                                <td>
                                    <a href="/edit_user/?user_id={{ user_obj.id }}" class="btn btn-primary btn-xs">编辑</a>
                                    <a href="" class="btn btn-danger btn-xs">删除</a>
                                </td>
                            </tr>
                        {% endfor %}
      """
      # 后端查询出用户想要编辑的数据对象 展示到前端页面供用户查看和编辑
      def edit_user(request):
        # 获取url问号后面的参数
        edit_id = request.GET.get('user_id')
        # 查询当前用户想要编辑的数据对象
        edit_obj = models.User.objects.filter(id=edit_id).first()
    
        if request.method == "POST":
            username = request.POST.get('username')
            password = request.POST.get('password')
            # 去数据库中修改对应的数据内容
            # 修改数据方式1
            # models.User.objects.filter(id=edit_id).update(username=username,password=password)
            """
                将filter查询出来的列表中所有的对象全部更新            批量更新操作
                只修改被修改的字段
            """
    
            # 修改数据方式2
            edit_obj.username = username
            edit_obj.password= password
            edit_obj.save()
            """
                上述方法当字段特别多的时候效率会非常的低
                从头到尾将数据的所有字段全部更新一边 无论该字段是否被修改
            """
            
            # 跳转到数据的展示页面
            return redirect('/userlist/')
    
    
    
        # 将数据对象展示到页面上
        return render(request,'edit_user.html',locals())
    
    # 删除功能
    	"""
    	跟编辑功能逻辑类似
    	def delete_user(request):
        # 获取用户想要删除的数据id值
        delete_id = request.GET.get('user_id')
        # 直接去数据库中找到对应的数据删除即可
        models.User.objects.filter(id=delete_id).delete()
        """
            批量删除
        """
        # 跳转到展示页面
    
        return redirect('/userlist/')	
    	
    	"""
    # 真正的删除功能应该需要二次确认 我们这里先不做后面会讲
    # 删除数据内部其实并不是真正的删除 我们会给数据添加一个标识字段用来表示当前数据是否被删除了,如果数据被删了仅仅只是讲字段修改一个状态
    	username password	is_delete
      jason			123				0
      egon			123				1
    

    2.django orm中如何创建表关系

    """
    表与表之间的关系
    	一对多
    	
    	多对多
    	
    	一对一
    	
    	没有关系
    
    判断表关系的方法:换位思考
    """
    图书表
    
    出版社表
    
    作者表
    
    作者详情表
    
    
    """
    图书和出版社是一对多的关系 外键字段建在多的那一方 book
    	
    图书和作者是多对多的关系 需要创建第三张表来专门存储
    
    作者与作者详情表是一对一
    """
    from django.db import models
    
    # Create your models here.
    
    
    # 创建表关系  先将基表创建出来 然后再添加外键字段
    class Book(models.Model):
        title = models.CharField(max_length=32)
        price = models.DecimalField(max_digits=8,decimal_places=2)
        # 总共八位 小数点后面占两位
        """
        图书和出版社是一对多 并且书是多的一方 所以外键字段放在书表里面
        """
        publish = models.ForeignKey(to='Publish')  # 默认就是与出版社表的主键字段做外键关联
        """
        如果字段对应的是ForeignKey 那么会orm会自动在字段的后面加_id
        如果你自作聪明的加了_id那么orm还是会在后面继续加_id
        
        后面在定义ForeignKey的时候就不要自己加_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后缀
        所以你也不要自作聪明的自己加_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后缀
    """
    
    # 在django1.X版本中外键默认都是级联更新删除的
    # 多对多的表关系可以有好几种创建方式 这里暂且先介绍一种
    # 针对外键字段里面的其他参数 暂时不要考虑 如果感兴趣自己可以百度试试看
    

    3.django请求生命周期流程图(必会)

    下图来自:https://www.cnblogs.com/guanxiying/p/12966067.html

    img

    # 每个人都要会画 这个图是你们后期复习django最好的一个梳理方式
    
    
    # 扩展知识点
    	"""
    	缓存数据库
    		提前已经将你想要的数据准备好了 你来直接拿就可以
    		提高效率和响应时间
    		
    	当你在修改你的数据的时候 你会发现数据并不是立刻修改完成的
    	而是需要经过一段时间才会修改
    		博客园
    	
    	了解即可
    	"""
    

    4.路由层

    路由匹配

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

    无名分组

    """
    分组:就是给某一段正则表达式用小括号扩起来
    """
    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')
    
    # 有名分组就是将括号内正则表达式匹配到的内容当作关键字参数传递给后面的视图函数
    

    无名有名是否可以混合使用

    """
    嘻嘻 不能混用
    但是同一个分组可以使用N多次
    """
    
    # 单个的分组可以使用多次
    url(r'^index/(d+)/(d+)/(d+)/',views.index),
    url(r'^index/(?P<year>d+)/(?P<age>d+)/(?P<month>d+)/',views.index),
    

    反向解析

    # 通过一些方法得到一个结果 该结果可以直接访问对应的url触发视图函数
    
    # 先给路由与视图函数起一个别名
    	url(r'^func_kkk/',views.func,name='ooo')
    # 反向解析
    	# 后端反向解析
      	from django.shortcuts import render,HttpResponse,redirect,reverse
      	reverse('ooo')
      # 前端反向解析
      	<a href="{% url 'ooo' %}">111</a>
    
  • 相关阅读:
    存储过程和函数
    linux命令行执行db2存储过程
    使用 springmvc请求 返回 字符串时 ,中文出现乱码
    shiro + struts2 在action 中使用 shiro 注解 @requiresPermissions 报错: 方法找不到,类初始失败
    spring 注解 注入属性 和 注解完成bean定义
    hibernate4 , spring3 使用 org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean 报错 Implementing class
    action spring 注入错误,如果检查各项注入都没有错误时,考虑struts 是否配置了namespace(如果你有多个namespace="/")
    urlrewritefilter 本地windowsxp 上正常 使用 ,但是 到linux服务器 上 则时好时坏 ,不起作用
    filter 死循环(tomcat 启动完成 ,自动执行filter.dofilter,导致tomcat 启动超时) , tomcat 启动和 servers 启动 不同
    项目 solrcloud / zookeeper 搭建
  • 原文地址:https://www.cnblogs.com/xuexianqi/p/12968416.html
Copyright © 2011-2022 走看看