zoukankan      html  css  js  c++  java
  • django orm

    django orm

    """
    ORM. 对象关系映射
    作用:能够让一个不用sql语句的小白也能够通过python 面向对象的代码简单快捷的操作数据库
    不足之处:封装程度太高 有时候sql语句的效率偏低 需要你自己写SQL语句
    
    类                                            表
    
    对象                                    记录
        
    对象属性                            记录某个字段对应的值
    
    
    应用下面的models.py文件
    """
    
    # 1 先去models.py中书写一个类
        class User(models.Model):
        # id int primary_key auto_increment
        id = models.AutoField(primary_key=True)
        # username varchar(32)
        username = models.CharField(max_length=32)
        # password int
        password = models.IntegerField()
    
    *************************# 2 数据库迁移命令*************************
    python3 manage.py makemigrations 将操作记录记录到小本本上(migrations文件夹)
    
    python3 manage.py migrate  将操作真正的同步到数据库中
    # 只要你修改了models.py中跟数据库相关的代码 就必须重新执行上述的两条命令
    ******************************************************************
    
    class User(models.Model):
        # id int primary_key auto_increment
        id = models.AutoField(primary_key=True,verbose_name='主键')
        # username varchar(32)
        username = models.CharField(max_length=32,verbose_name='用户名')
        """
        CharField必须要指定max_length参数 不指定会直接报错
        verbose_name该参数是所有字段都有的 就是用来对字段的解释
        """
        # password int
        password = models.IntegerField(verbose_name='密码')
    
    
    class Author(models.Model):
        # 由于一张表中必须要有一个主键字段 并且一般情况下都叫id字段
        # 所以orm当你不定义主键字段的时候 orm会自动帮你创建一个名为id主键字段
        # 也就意味着 后续我们在创建模型表的时候如果主键字段名没有额外的叫法 那么主键字段可以省略不写
        # username varchar(32)
        username = models.CharField(max_length=32)
        # password int
        password = models.IntegerField()

    字段的增删改查

    # 字段的增加
        1.可以在终端内直接给出默认值
      2.该字段可以为空
        info = models.CharField(max_length=32,verbose_name='个人简介',null=True)
      3.直接给字段设置默认值
        hobby = models.CharField(max_length=32,verbose_name='兴趣爱好',default='study')
     
    # 字段的修改
        直接修改代码然后执行数据库迁移的两条命令即可!
    
    # 字段的删
        直接注释对应的字段然后执行数据库迁移的两条命令即可!
      执行完毕之后字段对应的数据也都没有了
      
    """
    在操作models.py的时候一定要细心
        千万不要注释一些字段
        执行迁移命令之前最好先检查一下自己写的代码
    """
    
    # 个人建议:当你离开你的计算机之后一定要锁屏

    数据的增删改查

    #
    res = models.User.objects.filter(username=username)
    """
    返回值你先看成是列表套数据对象的格式
    它也支持索引取值 切片操作 但是不支持负数索引
    它也不推荐你使用索引的方式取值
    user_obj = models.User.objects.filter(username=username).first()
    """
    filter括号内可以携带多个参数 参数与参数之间默认是and关系
    你可以把filter联想成where记忆
    
    
    
    #
    from app01 import models
    res = models.User.objects.create(username=username,password=password)
    # 返回值就是当前被创建的对象本身
    
    # 第二种增加
    user_obj = models.User(username=username,password=password)
    user_obj.save()  # 保存数据

    # 先讲数据库中的数据全部展示到前端 然后给每一个数据两个按钮 一个编辑一个删除
    
    
    
    
    # 查看
    
    
    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
     
  • 相关阅读:
    Eclipse下载
    RTT之AT命令组件
    RTT之shell
    RTT之内存管理及异常中断
    单片机的图形UI
    RTT学习
    RTT学习之线程管理
    C++学习笔记:
    运放
    关于KEIL下的图形化显示和输出问题
  • 原文地址:https://www.cnblogs.com/mayrain/p/13054405.html
Copyright © 2011-2022 走看看