怎么用django来增删改查?

导读:本篇文章首席CTO笔记来给大家介绍有关怎么用django来增删改查的相关内容,希望对大家有所帮助,一起来看看吧。

django项目--菜单管理

后台首页菜单根据用户权限动态生成,不同菜单对应不同的功能视图。菜单的增删改查。

2 . 路由

1.html

django 怎么在admin里显示数据库的内容

操作方法:首先要运行python manage.py createsuperuser 命令来创建一个管理员账户。

然后在url中输入/admin 即可到达管理员登录页,登录之后会发现并没有数据库中要显示的项目,因为我们还没有注册。

接下来我们注册要在admin中管理的数据模型;在admin.py中注册模型。然后刷新页面,即可看到ContactMessage这个数据表了,可以在里边增删进行简单的增删改查。

怎么用django来增删改查?  第1张

第10节、案例-客户关系管理系统之增删改查笔记

第10节、案例-客户关系管理系统之增删改查笔记

一、建立模型

1、导入模型

fromdjango.dbimportmodels

2、创建学生表

classStudent(models.Model):# 学生表

name=models.CharField(max_length=20)

age=models.SmallIntegerField()

sex=models.SmallIntegerField(default=1)

qq=models.CharField(max_length=20,unique=True)

phone=models.CharField(max_length=20,unique=True)

c_time=models.DateTimeField(verbose_name='创建时间',auto_now_add=True)

e_time=models.DateTimeField(verbose_name='修改时间',auto_now=True)

grade=models.ForeignKey('Grade',on_delete=models.SET_NULL,null=True)

is_delete=models.BooleanField(default=False)# 一般实际开发过程中,我们不会直接删除数据,而是给数据加上is_delete字段,来标记数据的状态。

def__str__(self):

return'%s-%s-%s'%(self.name,self.age,self.sex)

3、创建学生详情表

classStudentDetail(models.Model):#学生详情表

num=models.CharField('身份证',max_length=40,unique=True)

college=models.CharField('毕业学校',max_length=20,default='')

student=models.OneToOneField('Student',on_delete=models.CASCADE,related_name='detail')

def__str__(self):

return'%s-%s'%(self.num,self.college)

4、创建班级表

classGrade(models.Model):# 班级表

name=models.CharField('班级名称',max_length=20)

num=models.CharField('班期',max_length=20)

def__str__(self):

return'%s-%s'%(self.name,self.num)

5、创建课程表

classCourse(models.Model):# 课程表

name=models.CharField('课程名称',max_length=20)

student=models.ManyToManyField('Student',through='Enroll')

def__str__(self):

return'%s'%self.name

6、创建学生表与课程表的中间表

classEnroll(models.Model):# 课程与学生多对多中间表

student=models.ForeignKey('Student',on_delete=models.CASCADE)

course=models.ForeignKey('Course',on_delete=models.CASCADE)

pay=models.FloatField('缴费金额',default=0)

c_time=models.DateTimeField(verbose_name='创建时间',auto_now_add=True)

def__str__(self):

return'%s'%self.pay

##

二、增删改查功能实现

1、index页面视图函数

fromdjango.shortcutsimportrender,redirect,reverse

fromdjango.httpimportHttpResponse

fromstudent.modelsimportStudent,Grade,StudentDetail

fromdjango.db.modelsimportQ

fromdjango.core.paginatorimportPaginator

# Create your views here.

defindex(request):

section='学生列表'

search=request.POST.get('search','').strip()# 接收从html的form表单传过来的参数

ifsearch:

ifsearch.isdigit():# 如果是数值类型则

sts=Student.objects.filter(Q(qq=search)|Q(phone=search),is_delete=False)# 用qq和phone去匹配

else:# 如果是字符型

sts=Student.objects.filter(name=search,is_delete=False)# 则和名字匹配

else:# search都没有匹配到则查询所有学生

sts=Student.objects.filter(is_delete=False)

sts=sts.order_by('-c_time')# 排序

returnrender(request,'student/index.html',context={

'sts':sts,

'section':section,

'search':search,

    })

2、学生删除页视图

defstudent_delete(request,pk):

student=Student.objects.get(pk=pk)# 查询id为pk的学生

student.is_delete=True# 将is_delete标记为True,

student.save()# 保存

returnredirect(reverse('student:index'))

3、学生详情页视图

defstudent_detail(request,pk):

section='学生详情'

grades=Grade.objects.all()# 查询所有班级

sts=Student.objects.get(pk=pk)# 获取当前id为pk的学生信息

grade=Grade.objects.get(pk=sts.grade_id)# 查询指定学生的班级

detail=StudentDetail.objects.get(student=sts)# 查询指定学生的详情

returnrender(request,'student/student_detail.html',context={

'section':section,

'grades':grades,

'sts':sts,

'grade':grade,

'detail':detail,

    })

4、添加页视图函数

defstudent_add(request):

section='添加学生信息'

grades=Grade.objects.all()# 获取所有的班级

ifrequest.method=='GET':

returnrender(request,'student/student_detail.html',context={

'section':section,

'grades':grades,

        })

ifrequest.method=='POST':

# 获取班级信息

grade_id=request.POST.get('grade')# 获取前端传回来的grade.id

try:

grade=Grade.objects.get(pk=grade_id)

except:

grade=None

# 获取学生信息姓名、年龄、性别、qq、电话

data= {

'name':request.POST.get('name'),

'age':request.POST.get('age'),

'sex':request.POST.get('sex'),

'qq':request.POST.get('qq'),

'phone':request.POST.get('phone'),

'grade':grade#表关联,在student中

        }

student=Student.objects.create(**data)

# 获取学生详情信息

StudentDetail.objects.create(

num=request.POST.get('num'),

college=request.POST.get('college'),

student=student# 表关联

        )

returnredirect(reverse('student:index'))

5、修改学生信息页视图函数

defstudent_edit(request,pk):

section='修改学生信息'

sts=Student.objects.get(pk=pk)# 查询id为pk的学生

grade=Grade.objects.get(pk=sts.grade_id)# 查询指定学生的班级

detail=StudentDetail.objects.get(student=sts)# 查询指定学生的详情

ifrequest.method=='GET':

returnrender(request,'student/student_detail.html',context={

'section':section,

'sts':sts,

'grade':grade,

'detail':detail,

        })

ifrequest.method=='POST':

# 获取班级信息

grade_id=request.POST.get('grade')# 获取前端传回来的grade

try:

grade=Grade.objects.get(pk=grade_id)# 获取学生的班级

except:

grade=None

# 获取学生信息并修改

student=Student.objects.get(pk=pk)

student.name=request.POST.get('name')

student.age=request.POST.get('age')

student.sex=request.POST.get('sex')

student.qq=request.POST.get('qq')

student.phone=request.POST.get('phone')

student.grade=grade# 表关联

# 获取学生详情

try:

detail=student.detail# 表关联,关联表在student

except:

detail=StudentDetail()

detail.student=student# 表关联,关联表在detail

detail.num=request.POST.get('num')

detail.college=request.POST.get('college')

detail.save()# 保存

student.save()# 保存

returnredirect(reverse('student:index'))

三、分页功能实现

1、对主页分页方法一

1.1主页的视图函数

defindex(request):

section='学生列表'

search=request.POST.get('search','').strip()# 接收从html的form表单传过来的参数

ifsearch:

ifsearch.isdigit():# 如果是数值类型则

sts=Student.objects.filter(Q(qq=search)|Q(phone=search),is_delete=False)# 用qq和phone去匹配

else:# 如果是字符型

sts=Student.objects.filter(name=search,is_delete=False)# 则和名字匹配

else:# search都没有匹配到则查询所有学生

sts=Student.objects.filter(is_delete=False)

sts=sts.order_by('-c_time')# 排序

# 分页

total_num=sts.count()# 总的数据量

per_page=int(request.GET.get('per_page',5))# 每页默认条数为5

page=int(request.GET.get('page',1))# 当前页面默认为第1页

p=Paginator(sts,per_page,allow_empty_first_page=True)

sts=p.get_page(page)# 每页显示的数据

total_page=p.num_pages# 总的页面数

page_list=p.page_range# 获取页面范围

returnrender(request,'student/index.html',context={

'sts':sts,

'section':section,

'search':search,

'total_num':total_num,

'total_page':total_page,

'page':page,

'per_page':per_page,

'page_list':page_list,

    })

1.2、html中页码的设置

navaria-label="Page navigation"style="display: inline-block"

ulclass="pagination"

li{%ifpage==1%}class="disabled"{%endif%}

ahref="{% if page 1 %}{% url 'student:index' %}?page={{ page|add:-1 }}per_page={{ per_page }}{% else %}{% url 'student:index' %}?page={{ page }}per_page={{ per_page }}{% endif %}"aria-label="Previous"

spanaria-hidden="true"上一页/span

/a

/li

            {% for i in page_list %}

li{%ifpage==i%}class="active"{%endif%}ahref="{{ request.path }}?page={{ i }}per_page={{ per_page }}"{{ i }}/a/li

            {% endfor %}

li{%ifpage==total_page%}class="disabled"{%endif%}

ahref="{% if page total_page %}{% url 'student:index' %}?page={{ page|add:1 }}per_page={{ per_page }}{% else %}{% url 'student:index' %}?page={{ page }}per_page={{ per_page }}{% endif %}"aria-label="Next"

spanaria-hidden="true"下一页/span

/a

/li

/ul

/nav

!-- Single button --

divclass="btn-group"style="display: inline-block; margin-top: -68px"

buttontype="button"class="btn btn-default dropdown-toggle"data-toggle="dropdown"aria-haspopup="true"aria-expanded="false"

{{ per_page }}条/页spanclass="caret"/span

/button

ulclass="dropdown-menu"

liahref="{% url 'student:index' %}?page={{ page}}per_page= 5 "5条/页/a/li

liahref="{% url 'student:index' %}?page={{ page}}per_page= 10 "10条/页/a/li

liahref="{% url 'student:index' %}?page={{ page}}per_page= 15 "15条/页/a/li

liahref="{% url 'student:index' %}?page={{ page}}per_page= 20 "20条/页/a/li

/ul

/div

2、对主页分页方法二(利用包含标签)

2.1、index中的视图函数

defindex(request):

section='学生列表'

search=request.POST.get('search','').strip()# 接收从html的form表单传过来的参数

ifsearch:

ifsearch.isdigit():# 如果是数值类型则

sts=Student.objects.filter(Q(qq=search)|Q(phone=search),is_delete=False)# 用qq和phone去匹配

else:# 如果是字符型

sts=Student.objects.filter(name=search,is_delete=False)# 则和名字匹配

else:# search都没有匹配到则查询所有学生

sts=Student.objects.filter(is_delete=False)

sts=sts.order_by('-c_time')# 排序

# 分页

total_num=sts.count()# 总的数据量

per_page=int(request.GET.get('per_page',5))# 每页默认条数为5

page=int(request.GET.get('page',1))# 当前页面默认为第1页

p=Paginator(sts,per_page,allow_empty_first_page=True)

sts=p.get_page(page)# 每页显示的数据

total_page=p.num_pages# 总的页面数

page_list=p.page_range# 获取页面范围

returnrender(request,'student/index.html',context={

'sts':sts,

'section':section,

'search':search,

'total_num':total_num,

'total_page':total_page,

'page':page,

'per_page':per_page,

'page_list':page_list,

    })

2.2、在templatetags文件夹中创建student_custormer_tags.py

#!/usr/bin/python

# -*- coding: utf-8 -*-

# author:cyb time:2019/5/25 23:34

fromdjangoimporttemplate

register=template.Library()

@register.inclusion_tag('student/paginitor.html',takes_context=True)

defpagination_html(context):# 谁引用就导入谁的context

total_page=context['total_page']# 总的页面数

page=context['page']# 显示第几页的数据

page_list=context['page_list']# 页面范围

per_page=context['per_page']# 每页条数

'''

    假设现在total_page = 6

    两种页码控制方法:

    当num = 1 # 当前页面左右各有几页

    上一页  1  2  3 下一页

    上一页  4  5  6 下一页

    上一页    1  2 下一页

    上一页  5  6    下一页

    当num = 2 # 当前页面左右各有几页

    上一页        1  2  3 下一页

    上一页    1  2  3  4 下一页

    上一页  1  2  3  4  5 下一页

    上一页  2  3  4  5  6 下一页

    上一页  4  5  6      下一页

    '''

page_list= []

num=2

# 1、左边 + 当前页显示的页码列表

# 1.1、左边不够显示时,页码范围1到当前页

ifpage-num=0:

foriinrange(1,page+1):

page_list.append(i)

else:# 左边够显示时,页码范围page-num到当前页

foriinrange(page-num,page+1):

page_list.append(i)

# 2、右边 + 当前页显示的页码列表

# 2.1、右边不够显示时,页码范围当前页到total_page

ifpage+num=total_page:

foriinrange(page+1,total_page+1):

page_list.append(i)

# 2.2、右边够显示时,页码范围(当前页+1)到(当前页+num)

else:

foriinrange(page+1,page+num):

page_list.append(i)

return{

'total_page':total_page,

'page':page,

'page_list':page_list,

'per_page':per_page

    }

2.3、在app中新建一个包含标签渲染模板paginitor.html

ulclass="pagination"

li{%ifpage==1%}class="disabled"{%endif%}

a{%ifpage1 %} href="{% url 'student:index' %}?page={{ page|add:'-1' }}per_page={{ per_page }}{% endif %}" aria-label="Previous"

spanaria-hidden="true"«/span

/a

/li

    {% for page_num in page_list %}

li{%ifpage_num==page%}class="active"{%endif%}ahref="{{ request.path }}?page={{ page_num }}per_page={{ per_page }}"{{ page_num }}/a/li

    {% endfor %}

li{%ifpage==total_page%}class="disabled"{%endif%}

a{%ifpage total_page %} href="{{ request.path }}?page={{ page|add:'1' }}per_page={{ per_page }}{% endif %}" aria-label="Next"

spanaria-hidden="true"»/span

/a

/li

/ul

2.4、在index.html中导入后在对应位置引用

1、导入:{% load student_customer_tags %}

2、引用:

nav aria-label="Page navigation" style="display: inline-block"

        {% pagination_html %}

/nav

四、页面展示

1、主页展示

2、添加页展示

3、修改页展示

学校的毕业设计是做一个美食网站,我能用python做吗,如果行,我还需要用哪些技术?求助

首先需要先找你的老师问一下, 有一些老师对技术有特殊偏好, 碰到这种情况他说什么你就怎么做就行了

如果对技术没要求的话, python是完全可以做出一个网站来的, 主要原因有如下几点

美食网站的本质是一个CMS系统, django自带django-admin, 可以快速的做一些增删改查的物料管理

如果用django写网站, 你只需要将重点放在如何写一个漂亮的页面就可以了, django数据库的使用方式ORM框架, 非常方便的写一些View, 然后render到你的模板上

使用Django常见了一个app,并连上了一个数据库,对这个数据库进行增删改查的代码应该编写在哪个文件中?

没有固定的要求,可以自己写一个文件统一管理,也可以在多个文件中随用的时候随写。

一旦建立好数据模型,Django 会自动为你生成一套数据库抽象的API,可以让你创建、检索、更新和删除对象,存放在models.py中。

model的更多操作可以参考。

结语:以上就是首席CTO笔记为大家整理的关于怎么用django来增删改查的全部内容了,感谢您花时间阅读本站内容,希望对您有所帮助,更多关于怎么用django来增删改查的相关内容别忘了在本站进行查找喔。

以上内容为新媒号(sinv.com.cn)为大家提供!新媒号,坚持更新大家所需的互联网后端知识。希望您喜欢!

版权申明:新媒号所有作品(图文、音视频)均由用户自行上传分享,仅供网友学习交流,不声明或保证其内容的正确性,如发现本站有涉嫌抄袭侵权/违法违规的内容。请发送邮件至 k2#88.com(替换@) 举报,一经查实,本站将立刻删除。

(0)
上一篇 2023-09-23 13:07
下一篇 2023-09-23 13:07

相关推荐

发表回复

登录后才能评论