Django是Python中一个非常牛逼的web框架,他帮我们做了很多事,里边也提前封装了很多牛逼的功能,用起来简直不要太爽,在写网站的过程中,增删改查这几个基本的功能我们是经常会用到,Django把这系列复杂的逻辑性东西都封装成了方法,供我们直接使用,在使用过程中的体会是简单到令人发指,一个简单的例子给大家演示一下。

首先创建一个有多对一关系关联模型

我们假设有一个主题,主题下边会有很多内容,然后我们将主题和内容用多对一的ForeignKey字段关联起来,如下:

# models.py

from django.db import models
from django.shortcuts import reverse class Topic(models.Model):
text = models.CharField('主题', max_length=100)
date_added = models.DateTimeField('添加时间', auto_now_add=True) class Meta:
ordering = ['-date_added']
verbose_name_plural = "主题" def __str__(self):
return self.text class Entry(models.Model):
topic = models.ForeignKey(Topic, on_delete=models.CASCADE, verbose_name="主题")
text = models.TextField('具体笔记')
date_added = models.DateTimeField('添加时间', auto_now_add=True) class Meta:
ordering = ['-date_added']
verbose_name_plural = "具体知识" def __str__(self):
return self.text[:50] + "..."

在视图views.py中我们使用了Django给我们提供的通用显示视图ListView(通用列表视图),DetailView(通用详情视图)来进行数据查询处理。

# views.py

from django.views.generic import ListView, DetailView  # 通用显示视图
from django.views.generic.edit import CreateView, DeleteView, UpdateView # 通用编辑视图
from . import models as md
from django.urls import reverse_lazy # 增删改成功后要跳转的链接方法引入 # 通用显示视图查询列表 ListView
class TopicsList(ListView):
model = md.Topic # 属于哪个模型
# 指定显示的静态模板
template_name = 'mysite/topics.html'
# 自定义上下文变量,我们最好自己设置,覆盖掉默认的上下文变量
context_object_name = 'topics' # 通用显示视图查询列表的详情页面 DetailView
class TopicDetail(DetailView):
model = md.Topic
template_name = 'mysite/topic.html'

接上文,在增删改查的过程中,我们使用了Django给我们提供的通用编辑视图来处理表单数据,CreateView(添加),UpdateView(更新),DeleteView(修改),如下:

# views.py

class TopicUpdate(UpdateView):
# 与通用显示视图一致,定义属于哪个模型
model = md.Topic
# 覆盖掉默认的视图模板,使用我们自定义的
template_name = 'mysite/edit_topic.html'
# 允许编辑的字段
fields = ['text']
# 修改成功后跳转的链接地址
success_url = reverse_lazy('mysite:topics') class TopicDelete(DeleteView):
model = md.Topic
template_name = 'mysite/del_topic.html'
success_url = reverse_lazy('mysite:topics') class EntryCreate(CreateView):
model = md.Entry
template_name = 'mysite/new_entry.html'
fields = ['topic', 'text']
success_url = reverse_lazy('mysite:topics')

接着在我们urls中定义链接,注意这里的urls.py文件位于我们的应用中,并不是在项目中的urls.py里,我们在项目中利用了include进行了url地址的分发,这样做的好处,请自行了解官方文档。

# urls.py

from django.urls import path
from . import views
from .views import TopicCreate, TopicUpdate, TopicDelete, EntryCreate app_name = 'mysite'
urlpatterns = [
path('topics/', views.TopicsList.as_view(), name='topics'),
path('topics/<int:pk>/', views.TopicDetail.as_view(), name='topic'),
path('topic/add/', TopicCreate.as_view(), name='topic-add'),
path('topic/<int:pk>/', TopicUpdate.as_view(), name='topic-update'),
path('topic/<int:pk>/delete/', TopicDelete.as_view(), name='topic-delete'), path('entry/add/', EntryCreate.as_view(), name='entry-add'),
]

最后来看看我们的在静态模板文件中如何调用

<!-- topics.html 中的调用代码 -->

 <a href="{% url 'mysite:topic-add' %}">添加主题</a>
{% if topics %}
{% for topic in topics %}
<li><a href="{% url 'mysite:topic' topic.id %}" >{{ topic.text }}</a> </li>
<a href="{% url 'mysite:topic-update' topic.id %}">修改</a>
<a href="{% url 'mysite:topic-delete' topic.id %}">删除</a>
{% endfor %}
{% else %}
<p>还没有任何主题</p>
{% endif %} <!-- topic.html 中的调用代码 --> <a href="{% url 'mysite:entry-add' %}">添加内容</a>
<h1>{{ topic }}</h1>
<!-- 请仔细体会我们这里用的 topic.entry_set.all 方法 -->
{% for entry in topic.entry_set.all %}
{{ entry.text }}
<p>日期:{{ entry.date_added }}</p>
{% endfor %}

其他几个静态模板调用方法几乎一样,只需要更换action的提交地址即可,留给大家的作业了

# new_topic.html

<form action="{% url 'mysite:topic-add' %}" method="post">
{% csrf_token %}
{{ form }}
<input type="submit" class="btn btn-block" value="提交">
</form>

还有笔记页面我只写了一个增加页面,其余几个留给大家练习,祝大家Django学习更上一层楼。
创作不易,我会持续分享关于Django的相关知识,有兴趣的朋友可以关注本人微信公众号:幸福关中

Django基于类的增删改查,简单逻辑都不用写的更多相关文章

  1. Node.js、express、mongodb 入门(基于easyui datagrid增删改查)

    前言 从在本机(win8.1)环境安装相关环境到做完这个demo大概不到两周时间,刚开始只是在本机安装环境并没有敲个Demo,从周末开始断断续续的想写一个,按照惯性思维就写一个增删改查吧,一方面是体验 ...

  2. Mybatis_3.基于注解的增删改查

    1.实体类User.java public class User { private int id; private String name; private int age; //getter.se ...

  3. ASP.NET Web API基于OData的增删改查,以及处理实体间关系

    本篇体验实现ASP.NET Web API基于OData的增删改查,以及处理实体间的关系. 首先是比较典型的一对多关系,Supplier和Product. public class Product { ...

  4. [转]ASP.NET Web API基于OData的增删改查,以及处理实体间关系

    本文转自:http://www.cnblogs.com/darrenji/p/4926334.html 本篇体验实现ASP.NET Web API基于OData的增删改查,以及处理实体间的关系. 首先 ...

  5. WPF MVVM+EF增删改查 简单示例(二) 1对1 映射

    WPF MVVM+EF增删改查 简单示例(一)实现了对学生信息的管理. 现在需求发生变更,在录入学生资料的时候同时需要录入学生的图片信息,并且一名学生只能有一张图片资料.并可对学生的图片资料进行更新. ...

  6. iOS sqlite 增删改查 简单封装(基于 FMDB)

    /** *  对 sqlite 的使用进行简单封装,仅涉及简单的单表 增删改查 * *  基于 FMDB * *  操作基于 model ,数据库表字段与 model 属性一一对应,对 model 整 ...

  7. Day 18 :面向对象[基础,继承,组合]类的增删改查

    有的人说,编程有3种范式: 1.面向过程:就是分析出解决问题所需要的步骤,然后用函数把这些步骤一步一步实现,使用的时候一个一个依次调用就可以了. 2.面向函数:面向函数是面向过程的升级版,也就是把每个 ...

  8. 用泛型创建SqlServerHelper类实现增删改查(一)

    使用泛型,可以构建对数据库单表的基本增删改查. 首先有一数据库 Test_SqlServerHelper ,有2表 接下来创建项目,对数据库进行增删改查. 直接贴代码:(SqlServerHelper ...

  9. Mybatis之基于XML的增删改查

    这里先吐槽下,写的半天的东西,IE浏览器弹出调试窗口导致写的东西全部没保存,搞得我还要重新用谷歌写,思路全没了,fuck. 前面学习了下spring的DAO层,说起DAO层,那ORM肯定是少不了的,O ...

随机推荐

  1. 《从0到1学习Flink》—— Flink Data transformation(转换)

    前言 在第一篇介绍 Flink 的文章 <<从0到1学习Flink>-- Apache Flink 介绍> 中就说过 Flink 程序的结构 Flink 应用程序结构就是如上图 ...

  2. &&运算符和||运算符的优先级问题 专题

    public class SyntaxTest { @Test public void test() { System.out.println(true || true && fals ...

  3. 【转】sql server数据库操作大全——常用语句/技巧集锦/经典语句

    本文为累计整理,有点乱,凑合着看吧! ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ ☆ ☆ ☆ sql 宝 典 ☆ ☆ ☆ 2012年-8月 修订版 ☆ ...

  4. css盒子模型 css3盒子相关样式

    1.内边距(内边距在content外,边框内) 内边距属性: padding          设置所有边距 padding-bottom     底边距 padding-left           ...

  5. 构建高性能JavaScript应用

    前端性能优化准则: 一.减少http请求.     措施:合并小图片,css控制背景图.合并CSS,合并JS 二.使用CDN(Content Deliver Network 内容分发网络)发布静态资源 ...

  6. OpenStack Ocata Telemetry 数据收集服务

    1 安装配置计算服务 在所有计算节点上: 1.1 安装配置组件 安装包: # yum install -y openstack-ceilometer-compute 编辑配置文件/etc/ceilom ...

  7. 【转发活动】Hey, 是你吗? | 寻"粉"启示

    你知道吗 从 A computer on every desk and in every home 让每张办公桌上和每个家庭都有一台计算机 ▼ 到 Where do you want to go to ...

  8. ubuntu16.04解决屏幕适应问题

    打开ubuntu登录进去后,输入: sudo  apt-get installopen-vm-tools sudo apt-get install open-vm* 然后重启(reboot),即可解决 ...

  9. pecl install msgpack

    Before the beginning: There are two php version, php5.5, php7.1. we need to install msgpack under ph ...

  10. win10安装mac系统

    https://baijiahao.baidu.com/s?id=1587241720383991895&wfr=spider&for=pc https://mp.weixin.qq. ...