时间:2021-05-22
上一篇我们写了Django基于类如何增删改数据的方法,方法虽然简单,但新手可能对其原理不是很清楚,那么我们这次就用Django提供的ModelForm方法来实现增删改数据,这是一种基于现有模型的增删改方法。
一个简单的例子加以说明,前提是你已经具备Django创建项目应用的基本知识:
01.首先创建一个简单的模型,模型只有三个文本字段,标题 title , 内容 text , 添加日期 date_added ,如下:
# models.py
from django.db import modelsfrom django.utils import timezoneclass Article(models.Model): title = models.CharField('标题', max_length=100) text = models.TextField('内容') date_added = models.DateTimeField(default=timezone.now) def __str__(self): return self.title创建完模型别忘了生成数据库, makemigrations 方法(生成迁移文件), migrate (迁移到数据库) 。
02.在项目中创建一个 form.py 的文件,我这里的项目名称是 app1 ,在其中创建继承一个 ModelForm 的表单类 ArticleForm ,他的子类中包含很多内置的方法,我都都可以对其覆盖,有兴趣的同学可以看官方文档,讲的非常详细。
文档地址: https://docs.djangoproject.com/zh-hans/2.1/topics/forms/modelforms/#django.forms.ModelForm ,
# form.pyfrom django.forms import ModelFormfrom .models import Articleclass ArticleForm(ModelForm): # 继承ModelForm类 class Meta: model = Article # 具体要操作那个模型 fields = ['title', 'text', 'date_added'] # 允许编辑的字段03.创建我们视图函数,开始增删改
# views.pyfrom django.shortcuts import render, redirect from .models import Articlefrom .form import ArticleFormdef articles(request): # 查询列表页面,获取Article的所有信息 articles = Article.objects.all() return render(request, 'app1/articles.html', {'articles':articles})# 与其对应的url,在应用中的urls.py中设置 path('article/', views.articles, name='article'),# 添加页面def new_article(request): # 如果不是POST方法访问 if request.method != 'POST': # 创建一个空表单在页面显示 form = ArticleForm() else: # 否则为POST方式 # request.POST方法,将会获取到表单中我们输入的数据 new_article = ArticleForm(request.POST) # 验证其合法性,使用is_valid()方法 if new_article.is_valid(): # 验证通过,使用save()方法保存数据 new_article.save() # 保存成功,使用redirect()跳转到指定页面 return redirect('app1:article') return render(request, 'app1/new_article.html', {'form':form})# 编辑修改页面def edit_article(request, article_id): # 查询到指定的数据 article = Article.objects.get(id=article_id) if request.method != 'POST': # 如果不是post,创建一个表单,并用instance=article当前数据填充表单 form = ArticleForm(instance=article) else: # 如果是post,instance=article当前数据填充表单,并用data=request.POST获取到表单里的内容 form = ArticleForm(instance=article, data=request.POST) form.save() # 保存 if form.is_valid(): # 验证 return redirect('app1:article') # 成功跳转 return render(request, 'app1/edit_article.html', {'form':form,'article':article})# 删除页面def del_article(request, article_id): article = Article.objects.get(id=article_id) if request.method == 'POST': article.delete() return redirect('app1:article') return render(request, 'app1/del_article.html', {'article': article})05.设置所有视图的url
06.静态页面调用
# articles.html <a href="{% url 'app1:new_article' %}" rel="external nofollow" >添加</a> {% for article in articles %} <h1>{{ article.title }}</h1> <p>{{ article.text }}</p> <a href="{% url 'app1:edit_article' article.id %}" rel="external nofollow" >修改</a> <a href="{% url 'app1:del_article' article.id %}" rel="external nofollow" >删除</a> {% endfor %}# new_article.html <form action="{% url 'app1:new_article' %}" method="post"> {% csrf_token %} {{ form.as_ul }} <input type="submit" value="提交"> </form>07.其他两个修改和删除页面的模板中调用方法与 new_article.html 中的方法一样,只需要更换 action 中的 url 即可。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
ORM对象关系映射在数据库中,实现对数据的增删改查,使用的是SQ语句,在django中,通过python代码,实现对数据库的增删改查,这就是ORM。在pytho
Mybatis的缓存mybatis是一个查询数据库的封装框架,主要是封装提供灵活的增删改sql,开发中,service层能够通过mybatis组件查询和修改数据
增删改查是对数据库最基本的操作,下面详细为大家介绍下如何连接数据库以及增删改查等等相关知识。 1.链接数据库通用方法:conn.php 代码如下: 2
本文实例讲述了thinkPHP数据库增删改查操作方法。分享给大家供大家参考,具体如下:thinkphp对数据库增删改查进行了封装操作,使得使用更加方便,但是不一
前言在Django中有大量的通用类视图,例如ListView,DetailView,CreateView,UpdateView等等,将所有重复的增删改查代码抽象