Django基础篇-2ORM 增删改查操作表

Posted fuyuteng

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Django基础篇-2ORM 增删改查操作表相关的知识,希望对你有一定的参考价值。

from django.shortcuts import render,HttpResponse,redirect
import os,sys
from django.views import View
from cmdb import models

# Create your views here.
User_dict ={
   "1":{"name":"大胖小子","age":18,"sex":"Man"},
   "2":{"name":"金虎","age":6,"sex":"Man"},
   "3":{"name":"妙音","age":5,"sex":"WoMan"},
   "4":{"name":"飞云","age":6,"sex":"Man"},
}
#主页
def index(request):
    return render(request,"index.html",{"User_dict":User_dict})


def login(request):
    if request.method == "GET":
        return render(request, "login.html")
    elif request.method == "POST":
        u=request.POST.get("user",None)
        p=request.POST.get("password",None)
        up=request.POST.get("update")
        update_msg = "更新%s密码成功!"%u
        if  models.UserInfo.objects.filter(username=u) and models.UserInfo.objects.filter(password=p):
            return render(request,zhuye.html,{"user":u})
        if  up =="更新":
            models.UserInfo.objects.filter(username=u).update(password=p)
            return render(request,login.html,{update_msg:update_msg})
        else:
            error_msg="用户名或密码错误"

    else:
        return  redirect("/index")
    return render(request, "login.html",{"error_msg":error_msg})

def zhuce(request):
    # if request.method == "GET":
    #     return render(request, "zhuce.html")
    # elif request.method == "POST":
    #     #radio
    #     radio = request.POST.get("gender")
    #     #chickbox
    #     chickbox = request.POST.getlist("favor")
    #     #select
    #     select=request.POST.getlist("city")
    #     #file
    #     send=request.FILES.get("send")
    #     print(send)
    #     file_path=os.path.join("upload",send.name)
    #     with open(file_path,mode="wb") as f:
    #         for i in send.chunks():
    #             f.write(i)
    # return render(request, "zhuce.html")
    if request.method == "GET":
        return render(request, "zhuce.html")
    elif request.method == "POST":
        username=request.POST.get("username")
        password=request.POST.get("password")
        models.UserInfo.objects.create(username=username,password=password)
        zhuce_msg = "注册成功!"
    return render(request, "zhuce.html",{"zhuce_msg":zhuce_msg})

class Home(View):

    def get(self,request):
        print(request.method)
        return render(request, "home.html")

    def post(self,request):
        u = request.POST.get("user", None)
        p = request.POST.get("pwd", None)
        if u == "root" and p == "123":
            return redirect(/index)
        else:
            error_msg = "用户名或密码错误"


        return render(request,"home.html", {"error_msg": error_msg})

def detail(request,nid):#通过url的nid参数传递过来,不用去request中的nid去获取值了
    detail_info=User_dict[nid]
    return render(request,"detail.html",{"detail_info":detail_info})

def orm(request):
    #创建
    #对UserInfo类(数据库表)进行增加操作
    username = request.POST.get("username")
    password = request.POST.get("password")
   # dic={‘username‘:username,‘password‘:password}
  #  models.UserInfo.objects.create(**dic)


    #models.UserInfo.objects.create(username=username,password=password) #推荐用这种添加数据库数据


    #obj = models.UserInfo(username="fuyuteng",password="123")
    #obj.save()创建数据第二种方法

    ‘‘‘查找所有‘‘‘
    #result=models.UserInfo.objects.all()
    ‘‘‘过滤查询username=root的所有符合查询的条件‘‘‘
    result = models.UserInfo.objects.filter(username=root)
    ‘‘‘删除‘‘‘
    delete=models.UserInfo.objects.filter(username=username,password=password).delete()#删除指定的  delete=models.UserInfo.objects.all().delete()#删除所有
    ‘‘‘update‘‘‘
    models.UserInfo.objects.update(password=password)#更新所有password的密码
    update=models.UserInfo.objects.filter(username=username).update(password=password)#更新指定用户名的密码

    return render(request,orm.html,{result:result})

以上是关于Django基础篇-2ORM 增删改查操作表的主要内容,如果未能解决你的问题,请参考以下文章

Django学习第6篇:Django之ORM单表操作(增删改查)

django框架学习:12.数据操作增删改查

Django之model基础(增删改查)

django-13.操作数据库(增删改查)

Django-Model操作数据库(增删改查连表结构)

Django 07. django框架模型之增删改查基本操作