python中mysqldb 增删改查 python增删改查的框架_Python


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

python中mysqldb 增删改查 python增删改查的框架_Django_02


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

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

#models.py from django.db import models
 from django.shortcuts import reverseclass 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’

#通用显示视图查询列表的详情页面 DetailViewclassTopicDetail(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, EntryCreateapp_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’),
 ]


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

添加主题 {% if topics %}
{% for topic in topics %}

  • {{ topic.text }}
  • 修改
    删除
    {% endfor %}
    {% else %}

    还没有任何主题
    {% endif %}
    添加内容

{{ topic }}

{% for entry in topic.entry_set.all %}
    {{ entry.text }}
   <p>日期:{{ entry.date_added }}</p>
{% endfor %}

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