【笔记】Django的ORM之删和改
【笔记】Django的ORM之删和改
一 删除操作
1.视图层
<table border="1">
<thead>
<tr>
<th>序号</th>
<th>ID</th>
<th>出版社名称</th>
<th>操作</th>
</tr>
</thead>
<tbody>
{% for publisher in publisher_list %}
<tr>
<td>{{ forloop.counter }}</td>
<td>{{ publisher.id }}</td>
<td>{{ publisher.name }}</td>
<td><ahref="/delete_publisher/?id={{ publisher.id }}">删除</a></td>
<td><ahref="/edit_publisher/?id={{ publisher.id }}">编辑</a></td>
</tr>
{% endfor %}
</tbody>
</table>
2. 逻辑层
通过GET方法向服务端传送要删除数据的id;
def delete_publisher(request):
# 通过GET方法获取id
del_id = request.GET.get('id', None)
# 如果取到id,删除该数据并跳转到列表页,否则提示失败
if del_id:
# 通过id拿到药删除的数据对象
del_obj = models.Publisher.objects.get(id=del_id)
del_obj.delete()
return redirect('/publisher_list/')
else:
return HttpResponse('删除失败,该出版社不存在')
二 修改操作
1. 视图层
与上面一样
2. 逻辑层
def edit_publisher(request):
# 如果是POST请求,说明是要更新出版社名称
if request.method == 'POST':
# 获取要更新的id
edit_id = request.POST.get("id", None)
# 获取新的名字
new_name = request.POST.get("publisher_name")
# 通过id获得出版社对象
publisher_obj = models.Publisher.objects.get(id=edit_id)
# 赋值新名字
publisher_obj.name = new_name
# 提交到数据库中执行
publisher_obj.save()
return redirect('/publisher_list/')
edit_id = request.GET.get("id", None)
if edit_id:
publisher_obj = models.Publisher.objects.get(id=edit_id)
return render(request, 'edit_publisher.html', {"publisher":publisher_obj})
else:
return HttpResponse('编辑的出版社不存在!')
三 其他
1. 下拉框
<form action="/edit_book/" method="post">
<input type="text" style="display: none" name="id" value="{{ edit_obj.id }}">
<p>书名:
<input type="text" name="book_title" value="{{ edit_obj.title }}">
</p>
<p>出版社名称:
<select name="publisher">
{% for publisher in all_publisher %}
{% if edit_obj.publisher.id == publisher.id %}
<optionselectedvalue="{{ publisher.id }}">{{ publisher.name }}</option>
{% else %}
<optionvalue="{{ publisher.id }}">{{ publisher.name }}</option>
{% endif %}
{% endfor %}
</select>
</p>
<p>
<input type="submit" value="提交">
</p>
</form>
2. 对已有数据的数据表添加字段

执行python3 manage.py makemigrations和python3 manage.py migrate时,可以通过以下方式找到一个执行窗口,更方便的执行。


【笔记】Django的ORM之删和改的更多相关文章
- python/Django(增、删、改、查)操作
python/Django(增.删.改.查)操作 我们要通过pycharm中的Django模块连接MySQL数据库进行对数据的操作. 一.创建Django项目(每创建一个项目都要进行以下设置) 1.如 ...
- 【笔记】Django的ORM之多对多表的增和删
[笔记]Django的ORM之多对多表的增和删 Django ORM 多对多 一 昨日补充:外键关联 外键在ORM中的关联方式: 与数据表相关的类都放到models.py文件中 class Book ...
- (17)模型层 -ORM之msql 单表的增、删、改、查 及其他操作
单表操作-增.删.改.查 ret=models.User.objects.filter(id=1) #这里的结果是一个queryset对象 ret=modles.User.Objects.filte ...
- Entity Framework 6 学习笔记2 — 增、删、改、显示简单代码示例
前言 通过 “Entity Framework 6 学习笔记1 — 介绍和安装方法”文章我相信大家对EF的安装应该没什么问题了,整体安装还是比较简单的,只需要通过Nuge搜索EF然后安装就可以了,这也 ...
- django单表操作,增、删、改、查
一.实现:增.删.改.查 1.获取所有数据显示在页面上 model.Classes.object.all(),拿到数据后,渲染给前端;前端通过for循环的方式,取出数据. 目的:通过classes(班 ...
- Dapper学习笔记(3)-增、删、改、查
一.建表 在数据库中建立如下三张表: CREATE TABLE [dbo].[T_User] ( , ) PRIMARY KEY NOT NULL, ) NOT NULL, ) NULL, ) NUL ...
- Android(java)学习笔记186:对ListView等列表组件中数据进行增、删、改操作
1.ListView介绍 解决大量的相似的数据显示问题 采用了MVC模式: M: model (数据模型) V: view (显示的视图) C: controller 控制器 入门案例: acit ...
- Java框架spring Boot学习笔记(五):Spring Boot操作MySQL数据库增、删、改、查
在pom.xml添加一下代码,添加操作MySQL的依赖jar包. <dependency> <groupId>org.springframework.boot</grou ...
- Android(java)学习笔记129:对ListView等列表组件中数据进行增、删、改操作
1. ListView介绍 解决大量的相似的数据显示问题 采用了MVC模式: M: model (数据模型) V: view (显示的视图) C: controller 控制器 入门案例: aci ...
随机推荐
- Git中远程仓库的使用
1.查看当前的远程库 要查看当前配置有哪些远程仓库,可以用 git remote 命令,它会列出每个远程库的简短名字.在克隆完某个项目后,至少可以看到一个名为 origin 的远程库,Git 默认使用 ...
- 配gzip的过滤器进行压缩解决表单加载慢问题
一个客户的表单上字段超过五百,经浏览器的调试器发现主要问题是从服务器取数据花费了大量时间,下载内容大小约1.2M,下载时间在10s左右,导致样式加载完大约在17s左右(不清除浏览器缓存).最终考虑利用 ...
- C++面向对象类的实例题目六
问题描述: 编写一个程序计算两个给定长方形的面积,其中在设计类成员函数addarea()(用于计算两个长方形的总面积)时使用对象作为参数. 程序代码: #include<iostream> ...
- 解析IFC数据并转成json格式
{ "com.bim.ifc.ifc2x3.ifc2x3tc1.IfcBuilding (#104)-": [{ "objKey": "GlobalI ...
- Effective Objective-C [下]
http://esoftmobile.com/2013/08/17/effective-objective-c-2/ Chapter 6: Blocks and Grand Central Dispa ...
- loj10098 分离的路径
传送门 分析 此题要先用tarjan求点双联通分量,注意在求解是要注意一条无向边只能走一次.求完之后我们发现原来的图会变成一棵树,对于 这棵树我们发现答案是(叶子节点数量+1)/2,实际便是每两个节点 ...
- 20169206 2016-2017-2 《网络攻防实践》 nmap的使用
Part I 使用nmap扫描ubuntu靶机 先给出nmap的官方中文操作手册https://nmap.org/man/zh/,其实并不太好用,而且有时候会打不开,但至少是官方手册. 探查操作系统 ...
- [译]Javascript中的数列
本文翻译youtube上的up主kudvenkat的javascript tutorial播放单 源地址在此: https://www.youtube.com/watch?v=PMsVM7rjupU& ...
- const与define的区别
const与#define最大的差别,Const在堆栈分配了空间,而#define只是把具体数值 直接传递到目标变量罢了.或者说,const的常量是一个Run-Time的概念,他在程 序中确确实实的存 ...
- Date的转换输出
public static void main(String[] args) { // TODO Auto-generated method stub //20131111怎么格式化成2013年11月 ...