django学习-12.访问不同url/接口地址实现对指定数据的增删改查功能
1.前言
通过前面博客【django学习-10.django连接mysql数据库和创建数据表】里的操作,我们已经成功在数据库【hongjingsheng_project】里创建了一张数据表【hello_person】。
接着,我们通过完整的前后端交互,来展示django框架如何通过相关操作来实现对指定的一个数据表【hello_person】进行数据的新增/编辑/查询/删除这四种基本操作。
细节:
①.为了单独验证对数据表【hello_person】进行数据的新增/编辑/查询/删除这四种基本操作,我们可以在项目绝对路径【helloworld/hello/】里新增一个【personViews.py】,这个【personViews.py】存放针对数据表【hello_person】相关操作(比如新增数据/修改数据/查询数据/删除数据等操作)的视图函数。
②.问题:为什么要新增一个【personViews.py】?
答案:因为为了跟项目绝对路径【helloworld/hello/views.py】里已存在的所有视图函数分开存放,方便后续维护代码的改动。(实际开发过程中也基本默认是按照一张数据表A来单独创建一个py文件来存放这张数据表A相关操作的视图函数。)
2.访问不同url/接口地址实现对指定数据的增删改查功能
2.1.首先, 对数据表【hello_person】新增一条数据的完整操作流程进行记录。
2.1.1.第一步:我们在项目绝对路径【helloworld/hello/personViews.py】里新增一个函数名为【create_person】的视图函数/接口,具体代码内容如下。
细节:
①.一个视图函数就是一个接口,只是每个人的称呼不一样。

# coding:utf-8
'''
@file: personDB.py
@author: 洪景盛
@ide: PyCharm
@createTime: 2021年01月20日 09点40分
@contactInformation: 727803257@qq.com
''' # 请从这行开始编写脚本 from django.shortcuts import render
from django.http import HttpResponse,Http404
from .models import Person # 该接口/视图函数的作用:在person表新增一条数据。
def create_person(request): import random
random_name = "洪景盛"+str(random.randint(1,999999999))
# print(random_name)
random_age = random.randint(1,99)
person = Person(name = random_name, age = random_age)
person.save()
return HttpResponse("<p>在person表成功新增了一条数据!这条数据的name值是:%s;这条数据的age值是:%s;</p>"%(random_name,random_age))
细节:
①.django框架的MTV模型内容和具体流程,可以查看该菜鸟教程地址:https://www.runoob.com/django/django-intro.html

2.1.2.第二步:我们在项目绝对路径【helloworld/helloworld/urls.py】里新增一个值为【url(r"^create_person/$",personViews.create_person)】的url匹配规则,具体代码内容如下。

2.1.3.第三步:启动django项目【helloworld】的服务。

2.1.4.第四步:在任一浏览器上,输入地址【http://127.0.0.1:8000/create_person/】后,查看打开的页面的数据展示。

2.2.接着, 对数据表【hello_person】修改一条数据的完整操作流程进行记录。
2.2.1.第一步:我们在项目绝对路径【helloworld/hello/personViews.py】里新增一个函数名为【update_person】的视图函数/接口,具体代码内容如下。

# 该视图函数的作用:按照不同条件,来修改person表指定的数据。
def update_person(request):
# 1.修改其中一个id=1的name字段的值,再save,相当于sql语法中的update操作;
test1 = Person.objects.get(id=1)
newName = "这是被修改的新名字" + str(random.randint(1,999999999))
test1.name = newName
test1.save() # 2.跟1相比,2的做法就是直接用一行代码来实现同样的修改功能;
# Person.objects.filter(id = 1).update(name = "这是被修改的新名字" + str(random.randint(1,999999999))) # 修改所有数据的表字段nane的值为“统一名字”
# Person.objects.all().update(name = "统一名字") return HttpResponse("修改数据成功!id为1的这条数据的表字段name的最新值为:%s"%newName)
2.2.2.第二步:我们在项目绝对路径【helloworld/helloworld/urls.py】里新增一个值为【url(r"^update_person_data/$",personViews.updata_person)】的url匹配规则,具体代码内容如下。

2.2.3.第三步:在任一浏览器上,输入地址【http://127.0.0.1:8000/update_person_data/】后,查看打开的页面的数据展示。

2.3.接着, 对数据表【hello_person】获取数据的完整操作流程进行记录。
2.3.1.第一步:我们在项目绝对路径【helloworld/hello/personViews.py】里新增一个函数名为【search_person】的视图函数/接口,具体代码内容如下。

# 该视图函数的作用:按照不同条件,来获取person表指定的数据。
def search_person(request): # 初始化
response = ""
# 通过objects这个模型管理器的all()获得所有数据行,相当于SQL中的SELECT * FROM
list = Person.objects.all()
# 通过for循环,输出所有数据
for i in list:
response = response + i.name + ' '
return HttpResponse(response)
2.3.2.第二步:我们在项目绝对路径【helloworld/helloworld/urls.py】里新增一个值为【url(r"^search_person_data/$",personViews.search_person)】的url匹配规则,具体代码内容如下。

2.3.3.第三步:在任一浏览器上,输入地址【http://127.0.0.1:8000/search_person_data/】后,查看打开的页面的数据展示。

2.4.接着, 对数据表【hello_person】删除数据的完整操作流程进行记录。
2.4.1.第一步:我们在项目绝对路径【helloworld/hello/personViews.py】里新增一个函数名为【delete_person】的视图函数/接口,具体代码内容如下。

2.4.2.第二步:我们在项目绝对路径【helloworld/helloworld/urls.py】里新增一个值为【url(r"^delete_person_data/$",personViews.delete_person)】的url匹配规则,具体代码内容如下。

2.4.3.第三步:在任一浏览器上,输入地址【http://127.0.0.1:8000/delete_person_data/】后,查看打开的页面的数据展示。

3.其他相关知识点学习链接
①.运用模型层知识点,对数据库简单的增删改查操作,可以参考菜鸟教程的这篇文章:https://www.runoob.com/django/django-model.html
②.对django框架的Model模型层的非官方的详细解释(非官方人员写的内容也都是基于官方文档来进行解读和编写,适合刚入门的我们学习),可以参考这篇文章:https://www.w3cschool.cn/django/django-model.html
③.django框架的Model模型层的详细解释的官方文档(任何知识点都能在官方文档找到,后期进行开发时遇到不懂的知识点可以查找官方文档相关知识点,官方文档可以理解为就是操作手册),可以参考这篇官方文档:https://docs.djangoproject.com/en/3.0/topics/db/models/
django学习-12.访问不同url/接口地址实现对指定数据的增删改查功能的更多相关文章
- Mybatis学习总结(二)—使用接口实现数据的增删改查
在这一篇中,让我们使用接口来实现一个用户数据的增删改查. 完成后的项目结构如下图所示: 在这里,person代表了一个用户的实体类.在该类中,描述了相关的信息,包括id.name.age.id_num ...
- Django框架之第二篇--app注册、静态文件配置、form表单提交、pycharm连接数据库、django使用mysql数据库、表字段的增删改查、表数据的增删改查
本节知识点大致为:静态文件配置.form表单提交数据后端如何获取.request方法.pycharm连接数据库,django使用mysql数据库.表字段的增删改查.表数据的增删改查 一.创建app,创 ...
- Django 06 Django模型基础1(ORM简介、数据库连接配置、模型的创建与映射、数据的增删改查)
Django 06 Django模型基础1(ORM简介.数据库连接配置.模型的创建与映射.数据的增删改查) 一.ORM系统 #django模型映射关系 #模型类-----数据表 #类属性-----表字 ...
- Django——6 模型基础ORM 数据库连接配置 模型的创建与映射 数据的增删改查
Django Django的ORM简介 数据库连接配置 模型的创建与映射 数据库的增删改查 增数据 查数据及补充 改数据 删数据 Django的ORM系统分析 ORM概念:对象关系映射(Objec ...
- ES6学习笔记(三):教你用js面向对象思维来实现 tab栏增删改查功能
前两篇文章主要介绍了类和对象.类的继承,如果想了解更多理论请查阅<ES6学习笔记(一):轻松搞懂面向对象编程.类和对象>.<ES6学习笔记(二):教你玩转类的继承和类的对象>, ...
- Django之数据表增删改查
Django数据增删改查: 上课代码 from django.shortcuts import render,HttpResponse # Create your views here. from a ...
- Mysql学习笔记(三)对表数据的增删改查。
正文内容. 这一部分是最简单的,也是最麻烦的.简单是因为其实只包括增删该插四个部分.大体上看,增加数据.删除数据.修改数据.查询数据都不麻烦啊,我们日常都是常用的.这个谁不会呢?以前在培训机构学mys ...
- 【java学习】spring mvc 公共dao的实现,定义基本的增删改查
接口类: package com.blog.db.dao; import com.blog.util.Pagination; import java.util.List; public interfa ...
- Mybatis学习(3)实现数据的增删改查
前面已经讲到用接口的方式编程.这种方式,要注意的一个地方就是.在User.xml 的配置文件中,mapper namespace="com.yihaomen.mybatis.inter.I ...
随机推荐
- python——模块、标准库、第三方模块安装
模块(module)简介 模块化--指将一个完整的程序分解为一个一个小的模块,通过将模块组合,来搭建出一个完整的程序. 模块化的特点: ① 方便开发 ② 方便维护 ③ 模块可以复用! 在Python中 ...
- 4. DHCP配置(Windows2012)
1.点击服务器管理器 2.选择添加角色和功能 3. 按照添加角色和功能向导来添加 保持默认,下一步 保持默认,下一步 保持默认,下一步 勾选DHCP服务器,在弹出的小窗点击添加功能. 保持默认,下一步 ...
- kafka的演进历史
首先如果我开始做一个消息队列,最开始的时候可能就是一台单机上的一个单一的log日志,不断地向这个日志中追加消息即可. 后来,可能由于一个log日志支撑不了太多的读写请求,于是就对这个log日志进行了拆 ...
- docker(4)解决pull镜像速度缓慢
前言 上一篇讲到pull 镜像,但是pull镜像的时候下拉的速度实在感人,有什么解决办法吗?我们只需将docker镜像源修改为国内的 将docker镜像源修改为国内的: 在 /etc/docker/d ...
- 正点原子DS100拆解全过程-硬件工程师必备
前言: 之前一篇只针对正点原子DS100手持示波器的使用介绍文章.可作为一个电子工程师,光使用不是我们的风格哈,我们还要拆开看看电路. 开拆 外壳 首先,看下图,DS100不是使用螺母进行固定的,而是 ...
- 前n项余数个数和
一:O(n) 计算贡献:前n项中,能被i(1~n)整除的数的个数为(n/i)个,,也就是 i 给前n项中(n/i)个数做了余数 #include<iostream> using names ...
- Codeforces Round #625 (Div. 2, based on Technocup 2020 Final Round) C. Remove Adjacent(字符串,贪心,枚举)
题意: 给你一个由小写字母组成的字符串,若串中两个相邻元素字典序中也相邻,移除较大字母,问最多能移除多少个字母. 思路: 从大到小依次枚举. Tips: 注意下标的处理. 以小消大: #include ...
- Codeforces Round #676 (Div. 2) XORwice、Putting Bricks in the Wall、Palindromifier
题目链接:XORwice 题意:给你两个数a.b.求一个数x,使得((a异或x)+(b异或x))这个值最小,输出最小那个x 题解: 输出(a|b)-(a&b)就行(猜了一手 代码: #incl ...
- Codeforces Round #651 (Div. 2) A. Maximum GCD (思维)
题意:在\(1\)~\(n\)中找两个不相等的数使得他们的\(gcd\)最大. 题解:水题,如果\(n\)是偶数,那么一定取\(n\)和\(n/2\),\(n\)是奇数的话,取\(n-1\)和\((n ...
- Typora Themes自定义
Typora Themes自定义 Typora 支持css样式,自定义主题十分方便,修改自己的css文件,再放入其themes文件夹,重启Typora,即可看到自定义主题. Typora 官网,自定义 ...