from django import forms
from django.shortcuts import render, redirect
from app01 import models
# Create your views here.
def depart_list(request):
    """ 部门列表 """
    # 去数据库中获取所有的部门列表
    # queryset 理解为 [对象,对象,对象]  要循环才取的出来
    queryset = models.Department.objects.all()  # 获取所有部门列表的信息
    # 把 queryset 当作参数传递给 render ,内部在模板渲染的时候就可以取到 queryset
    return render(request, "depart_list.html", {'queryset': queryset})
def depart_add(request):
    """ 添加部门 """
    if request.method == "GET":
        return render(request, "depart_add.html")
    # 获取用户POST提交过来的数据 (title输入为空)
    title = request.POST.get("title")
    # 保存到数据库
    models.Department.objects.create(title=title)
    # 重定向回部门列表
    return redirect("/depart/list/")
def depart_delete(request):
    """ 删除部门 """
    # 获取ID
    nid = request.GET.get('nid')
    # 删除
    models.Department.objects.filter(id=nid).delete()
    # 跳转回
    return redirect("/depart/list/")
def depart_edit(request, nid):
    """ 修改部门 """
    if request.method == "GET":
        # 根据nid,获取他的数据 [obj,]
        row_object = models.Department.objects.filter(id=nid).first()
        # print(row_object.id, row_object.title)
        return render(request, "depart_edit.html", {"row_object": row_object})
    # 获取用户提交的标题
    title = request.POST.get("title")
    print(title)
    # 根据ID找到数据库中的数据,并进行更新
    # models.Department.objects.filter(id=nid).update(title=title, 其他=123) 多个或者其他 其他上面获取,这里更新
    models.Department.objects.filter(id=nid).update(title=title)
    # 重定向回部门列表
    return redirect("/depart/list/")
def user_list(request):
    """ 用户管理 """
    # 获取所有用户列表 [对象,对象,obj,obj]
    queryset = models.UserInfo.objects.all()
    # 用python的语法获取数据
    """
    for obj in queryset:
    print(obj.id, obj.name,obj.account,obj.create_time.strftime("%Y-%m-%d"),obj.gender,obj.get_gender_display(),obj.depart_id,obj.depart.title)
    # datetime.datetime 转字符串 .strftime("%Y-%m-%d-%H-%M")  用python的语法获取数据
    # <td>{{ obj.create_time|date:"Y-m-d H:i:s" }}</td>  在HTML中对时间的处理,所有的都不加括号
    # print(type(obj.create_time),type(obj.create_time.strftime("%Y-%m-%d")))
    # obj.gender 对应的是数据库储存的1/2
    # obj.get_gender_display()  # 根据数值1/2 去找对应的文本内容,不用自己去找   get_字段名_display()
    # xx = models.Department.objects.filter(id=obj.depart_id).first()   # 手动写代码把id=obj.depart_id去找相关的表
    # xx.title  # 在相关的表中取 title
    # obj.depart_id  # 获取数据库中存储的那个字段
    # obj.depart.title  # 根据id自动去关联的表中获取哪一行数据 depart对象。
    """
    return render(request, 'user_list.html', {"queryset": queryset})
def user_add(request):
    """ 添加用户 """
    context = {
        'gender_choices': models.UserInfo.gender_choices,
        'depart_list': models.Department.objects.all()
    }
    return render(request, "user_add.html", context)
# ################### ModelForm 示例###################
class UserModelForm(forms.ModelForm):
    # name 字符串长度最小等于3
    name = forms.CharField(min_length=3, label="用户名")
    # 校验所有数据是否为空
    class Meta:
        model = models.UserInfo
        fields = "__all__"  # 自动显示所有
        # fields = ["name", "password", "age", "account", "create_time", "gender", "depart"
        #   ]   # 指定显示哪些
        exclude = ['depart']  # 除了depart都显示,哪里有问题
        # widgets = {
        #     "name": forms.TextInput(attrs={"class": "form-control"}),
        #     "password": forms.PasswordInput(attrs={"class": "form-control"}),
        #     "age": forms.TextInput(attrs={"class": "form-control"}),
        # }
    def __init__(self, *args, **kwargs):  # 重新定义它的__init__方法
        super().__init__(*args, **kwargs)  # 执行它父类定义的方法
        # 循环找到所有的插件,添加了class="form-control"
        for name, field in self.fields.items():
            # if name == "password":  不添加样式的可以在这里判断一下
            #     continue
            # print(name, field)  # name可以拿到所有定义的字段,名字。field 可以拿到它对象
            field.widget.attrs = {"class": "form-control",
                                  "placeholder": field.label}  # widget 表示拿到的插件
def user_model_form_add(request):
    """ 添加用户(ModelForm版本) """
    if request.method == "GET":
        form = UserModelForm()
        return render(request, 'user_model_form_add.html', {"form": form})
    # 用户POST提交的数据,数据校验。
    form = UserModelForm(data=request.POST)
    if form.is_valid():
        # 如果数据合法,保存到数据库
        # {'name': '123', 'password': '123', 'age': 11, 'account': Decimal('1'), 'create_time': datetime.datetime(2011, 11, 12, 0, 0, tzinfo=zoneinfo.ZoneInfo(key='UTC')), 'gender': 2, 'depart': <Department: IT部门>}
        # print(form.cleaned_data)
        # models.UserInfo.objects.create(...)  # 保存到数据库
        form.save()  # 自动将提交的数据保存到数据库的表里面 那个表(定义的这个表 model = models.UserInfo)
        return redirect('/user/list/')
    # 校验失败(在页面上显示错误信息)
        # print(form.errors)
    return render(request, 'user_model_form_add.html', {"form": form})
def user_edit(request, nid):
    """ 编辑用户 """
    row_object = models.UserInfo.objects.filter(id=nid).first()
    if request.method == "GET":
        # 根据ID去数据库获取要编辑的那一行数据(对象) instance=row_object  modelform默认在页面显示每一个
        form = UserModelForm(instance=row_object)
        return render(request, 'user_edit.html', {'form': form})
    # instance=row_object 不是添加,而是更新
    form = UserModelForm(data=request.POST, instance=row_object)
    if form.is_valid():
        # 默认保存的是用户输入的所有数据,如果想要再用户输入以外增加一点值
        # form.instance.字段名 = 值
        form.save()
        return redirect('/user/list/')
    return render(request, 'user_edit.html', {"form": form})
def user_delete(request, nid):
    models.UserInfo.objects.filter(id=nid).delete()
    return redirect('/user/list/')

Django views.py 增,删,改的更多相关文章

  1. django 多对多 增 删 改 查

      一.通过url方式实现多对多的:增加,删除,编辑 代码目录: urls.py 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 ...

  2. django一对多 增 删 改 查

    实现一对多表查询功能 项目代码: models.py from django.db import models # Create your models here. class Classes(mod ...

  3. django ajax增 删 改 查

    具于django ajax实现增 删 改 查功能 代码示例: 代码: urls.py from django.conf.urls import url from django.contrib impo ...

  4. C# ADO.NET (sql语句连接方式)(增,删,改)

    using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.We ...

  5. 好用的SQL TVP~~独家赠送[增-删-改-查]的例子

    以前总是追求新东西,发现基础才是最重要的,今年主要的目标是精通SQL查询和SQL性能优化.  本系列主要是针对T-SQL的总结. [T-SQL基础]01.单表查询-几道sql查询题 [T-SQL基础] ...

  6. iOS FMDB的使用(增,删,改,查,sqlite存取图片)

    iOS FMDB的使用(增,删,改,查,sqlite存取图片) 在上一篇博客我对sqlite的基本使用进行了详细介绍... 但是在实际开发中原生使用的频率是很少的... 这篇博客我将会较全面的介绍FM ...

  7. iOS sqlite3 的基本使用(增 删 改 查)

    iOS sqlite3 的基本使用(增 删 改 查) 这篇博客不会讲述太多sql语言,目的重在实现sqlite3的一些基本操作. 例:增 删 改 查 如果想了解更多的sql语言可以利用强大的互联网. ...

  8. ADO.NET 增 删 改 查

    ADO.NET:(数据访问技术)就是将C#和MSSQL连接起来的一个纽带 可以通过ADO.NET将内存中的临时数据写入到数据库中 也可以将数据库中的数据提取到内存中供程序调用 ADO.NET所有数据访 ...

  9. MVC EF 增 删 改 查

    using System;using System.Collections.Generic;using System.Linq;using System.Web;//using System.Data ...

  10. 第18课-数据库开发及ado.net 连接数据库.增.删.改向表中插入数据并且返回自动编号.SQLDataReade读取数据

    第18课-数据库开发及ado.net 连接数据库.增.删.改向表中插入数据并且返回自动编号.SQLDataReade读取数据 ADO.NET 为什么要学习? 我们要搭建一个平台(Web/Winform ...

随机推荐

  1. 2022NewStarCTF新生赛一些比较有意思的题目wp

    Misc_蚁剑流量分析 Pcap的文件可以直接使用工具 编辑器打开目录,一个一个看,可以找到eval危险函数 看到n3wst4r,直接使用linux正则匹配,找出相关内容 Url解码,了解一下蚁剑流量 ...

  2. 沁恒微(WCH)CH395/392配置使用,代码指南 网路接口芯片 CH395 CH392

    CH395/CH392相关资料可以从官网下载具体连接可以看博客:WCH以太网相关芯片资料总结 里面是WCH官网相关信息的链接. 也可以去Gitee上下载:Gitee链接. STM32控制CH395的例 ...

  3. LeetCode-03 无重复字符的最长子串(Longest Substring Without Repeating Characters)

    题目描述 给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度. 示例 示例  1: 输入: "abcabcbb" 输出: 3 解释: 因为无重复字符的最长子串是 &qu ...

  4. LIS求解(包括优化)

    首先,让我来看看LIS问题 Description 一个数的序列 bi,当 b1 < b2 < ... < bS 的时候,我们称这个序列是上升的.对于给定的一个序列(a1,a2,.. ...

  5. ESP-01S无线下载器

    文章结构: 项目概述 成品预览 项目框架 硬件资料,代码 项目槽点 -项目概述- 最开始学习51的时候,总是"冷启动",手动按动开关重启,下载一次程序重启一次,觉得很麻烦 而且另一 ...

  6. Hugging Face 开源库介绍

    Hugging Face 的开源生态今年成长迅速,timm 成为新加入的成员.diffusers.evaluate 以及 skops 等各种库蓬勃发展. Transformers Transforme ...

  7. Ubuntu 安装配置 Java 环境

    下载 Java 官网 https://www.oracle.com/java/technologies/downloads/ https://www.oracle.com/cn/java/techno ...

  8. Docker使用阿里云拉取配置源也无法拉取的镜像-github镜像镜像gcr.io

    我搞了一天都没搞好,最后用了这个办法解决了拉取镜像的问题 对于大部分镜像来说,我们配置源就可以,但是对于较新的镜像,没得搞啊,铁子们,真的崩溃... 最终发现可以通过Aliyun的自动构建来处理被墙镜 ...

  9. Java基础学习笔记-类的静态属性和静态方法--待继续补充

    程序运行时的内存占用 代码区(code area) 存放代码 数据区(data area) 存放全局数据.静态数据 堆区(heap area) 存放动态申请的数据 栈区(stack area) 存放局 ...

  10. Objects非空判断-声明异常throws

    Objects非空判断 还记得我们学习过一个类Objects吗,曾经提到过它由一些静态的实用方法组成,这些方法是null-save(空指针安全的)或null-tolerant (容忍空指针的),那么在 ...