python在Django框架下实现增删改查功能

from django.shortcuts import render

#引入数据表
from app01.models import DepartInfo,UserInfo

#重定向
from django.http import HttpResponseRedirect

from django.core.paginator import Paginator,EmptyPage,PageNotAnInteger

# Create your views here.

#首页
def gotoIndex(request):
    return render(request,'index.html')

#跳转到添加部门页面
def gotoDepart(request):
    return render(request,'depart/addDepart.html')

#添加部门信息
def addDepartInfo(request):
    #获取部门信息
    departName=request.POST.get("departName")
    #保存部门信息
    # print('-------------------')
    # print(departName)
    #判断部门是否存在
    if DepartInfo.objects.filter(dName=departName):
        return render(request,'depart/addDepart.html',{"msg":"部门已经存在"})
    else:
        #判断是否添加内容
        if DepartInfo(dName=departName):
            DepartInfo(dName=departName).save()
            return render(request,'depart/addDepart.html',{"msg":"部门添加成功"})
        else:
            return render(request,'depart/addDepart.html',{"msg":"部门添加失败"})


#跳转到添加员工信息
def gotoUser(request):
    #获取所有部门  表
    departInfo=DepartInfo.objects.all()
    #返回到客户端 html
    return render(request,'user/addUser1.html',{"departInfo":departInfo})

#添加员工信息1===>2
def addUserName(request):
    #获取客户端数据 html
    departId=request.GET.get("departId")
    uName=request.GET.get("uName")
    departName=DepartInfo.objects.get(dId=departId).dName
    print(departId,uName)
    #保存数据,进行数据缓存
    #存的是部门id
    request.session['departId']=departId
    #员工姓名
    request.session['uName']=uName
    dict1={"departId":departId,'uName':uName,"departName":departName}
    return render(request,'user/addUser2.html',dict1)

#添加员工信息2===》3
def addUserNumSex(request):
    #获取客户端信息
    #性别
    uSex=request.GET.get("uSex")
    #工号
    uNum=request.GET.get("uNum")
    print(uSex,uNum)
    #保存数据
    request.session['uSex']=uSex
    request.session['uNum']=uNum
    if uSex=="1":
        uSex="男"
    elif uSex=="2":
        uSex="女"
    dict1={"uSex":uSex,"uNum":uNum}
    return render(request,'user/addUser3.html',dict1)

#保存员工信息3
def addUserMoney(request):
    #获取客户端数据
    uMoney=request.GET.get("uMoney")
    
    #保存数据
    #存的是部门id
    departId=request.session['departId']
    #员工姓名
    uName=request.session['uName']
    uSex=request.session['uSex']
    uNum=request.session['uNum']
    # print('---------')
    # print(uMoney,departId,uName,uSex,uNum)
    if UserInfo(dId=departId,uName=uName,uNum=uNum,usex=uSex,umoney=uMoney):
        UserInfo(dId=departId,uName=uName,uNum=uNum,usex=uSex,umoney=uMoney).save()
        return render(request,'user/addUser3.html')

#返回2===》1
def backUserName(request):
    #存的是部门id
    departId=request.session['departId']
    departName=DepartInfo.objects.get(dId=departId).dName
    departInfo=DepartInfo.objects.all()
    #员工姓名
    uName=request.session['uName']
    dict1={"departId":departId,'uName':uName,"departName":departName,"departInfo":departInfo,"flag":"1"}
    return render(request,'user/addUser1.html',dict1)

#返回3===》2
def backUserNum(request):
    uSex=request.session['uSex']
    uNum=request.session['uNum']
    if uSex=="1":
        dict1={"uSex":uSex,"uNum":uNum,"sexTrue":"1"}
        return render(request,'user/addUser2.html',dict1)
    elif uSex=="2":
        dict1={"uSex":uSex,"uNum":uNum}
        return render(request,'user/addUser2.html',dict1)    

#展示员工信息
def gotoShowUserInfo(request):
    userInfo=UserInfo.objects.all()
    for i in userInfo:
        #员工信息表的部门id=部门表的名称
        i.dId=DepartInfo.objects.get(dId=i.dId).dName
        if i.usex==1:
            i.usex="男"
        elif i.usex==2:
            i.usex="女"
    pagesize=1
    pages=Paginator(userInfo,pagesize)
    p=request.GET.get("p")
    try:
        pageDatas=pages.page(p)
    except PageNotAnInteger:
        pageDatas=pages.page(1)
    except EmptyPage:
        pageDatas=pages.page(pages.num_pages)
    return render(request,'user/showUserInfo.html',{"userInfo":pageDatas})    


#编辑员工信息
def gotoUpdateUser(request):
    #获取客户端参数
    uId=request.GET.get("uId")
    #返回夫服务器数据
    userInfo=UserInfo.objects.get(uId=uId)

    dName=DepartInfo.objects.get(dId=userInfo.dId).dName
    departInfo=DepartInfo.objects.all()
    if userInfo.usex==1:
        return render(request,'user/updateUserInfo.html',{"userInfo":userInfo,"dName":dName,"departInfo":departInfo,"seTrue":"1"})    
    elif userInfo.usex==2:
        return render(request,'user/updateUserInfo.html',{"userInfo":userInfo,"dName":dName,"departInfo":departInfo})    
    
#编辑员工信息
def updateUserInfo(request):
    #获取客户端数据
    uId=request.GET.get("uId")
    departId=request.GET.get("departId")
    #departId=DepartInfo.objects.get(dName=departId)
    uName=request.GET.get("uName")
    uSex=request.GET.get("uSex")
    uNum=request.GET.get("uNum")
    uMoney=request.GET.get("uMoney")
    print(departId,uName,uSex,uNum,uMoney)
    #修改保存数据
    if UserInfo.objects.filter(uId=uId):
        UserInfo.objects.filter(uId=uId).update(dId=departId,uName=uName,uNum=uNum,usex=uSex,umoney=uMoney)
    
    return HttpResponseRedirect('/gotoShowUserInfo')
    #return render(request,'user/showUserInfo.html')

#删除函数
def gotoDeleteUser(request):
    uId=request.GET.get("uId")
    UserInfo.objects.filter(uId=uId).delete()
    return HttpResponseRedirect('/gotoShowUserInfo')

#批量删除
def dodeleteUserInfoAll(request):
    uids=request.GET.get("uids")
    #return HttpResponseRedirect('/gotoShowUserInfo')
    UserInfo.objects.extra(where=['uId in ('+uids+')']).delete()
    return HttpResponseRedirect('/gotoShowUserInfo')

#搜索
def gotoSearch(request):
    #获取客户端数据
    searTxt=request.GET.get("searTxt")
    departInfo=DepartInfo.objects.filter(dName__contains=searTxt)
    for i in departInfo:
        print(i.dId)
        #进行搜索
        userInfo=UserInfo.objects.filter(dId=i.dId)
        for i in userInfo:
            i.dId=DepartInfo.objects.get(dId=i.dId).dName
            if i.usex==1:
                i.usex="男"
            elif i.usex==2:
                i.usex="女"
    pagesize=1
    pages=Paginator(userInfo,pagesize)
    p=request.GET.get("p")
    try:
        pageDatas=pages.page(p)
    except PageNotAnInteger:
        pageDatas=pages.page(1)
    except EmptyPage:
        pageDatas=pages.page(pages.num_pages)
    return render(request,'user/showUserInfo.html',{"userInfo":pageDatas,"searTxt":searTxt})

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值