Django笔记&教程 5-1 基础增删查改
Django 自学笔记兼学习教程第5章第1节——基础增删查改
点击查看教程总目录
第四章介绍了模型类models.Model和创建模型,相当于介绍了数据库表和如何创建数据库表。
这一章将介绍如何使用模型对数据库表进行增删查改,
注意:修改了模型类models.Model后一定要更新数据库(详见第四章第一节第三部分),如果数据库表进行增删查改则不必。
0 - 超实用工具介绍——Django下的交互式命令行
Django项目中,如果在项目实际使用的代码中,通过增删查改实现对应的业务逻辑,
测试起来会比较麻烦,(往往需要运行项目,按照一定的业务逻辑去重复性的手动测试),这种情况下,使用代码进行测试是一种更好的选择。
所以我们需要一个场景,可以直接运行代码,以方便我们测试业务代码逻辑本身是否正确。
这个时候,python的交互式命令行,就是一个十分有用的工具了,
但是导入项目本身依赖的配置和文件则有点麻烦,而Django本身则提供了一个方法解决这个问题。
在项目所在文件夹下打开命令行窗口,运行
python manage.py shell
即可开启导入了项目设置的命令行窗口,这时要使用项目中的某一代码文件中的代码,则像项目中编写代码那样正常导入即可。
示例效果如下
F:\my_projects\demo2>python manage.py shell
Python 3.6.5 (v3.6.5:f59c0932b4, Mar 28 2018, 17:00:18) [MSC v.1900 64 bit (AMD64)] on win32
Type "help", "copyright", "credits" or "license" for more information.
(InteractiveConsole)
>>> from myapp import models
>>>
1 - 增(Create)——添加数据
myapp/models.py如下:
from django.db import models
class Person(models.Model):
gender = (
('male', '男'),
('female', '女'),
)
name = models.CharField(max_length=60)
sex = models.CharField(max_length=32, choices=gender, default='男')
age = models.IntegerField()
要在数据库中增加记录,在Django下的交互式命令行执行代码如下
>>> from myapp.models import Person
>>> person = Person(name="Big Shuang", sex="male", age=24)
>>> person.save()
即可在数据库表中成功添加一行记录,如下
| id | name | sex | age |
|---|---|---|---|
| 1 | Big Shuang | male | 24 |
然后我们看下执行的代码,其实主要就是后两行
第二行创建一个 Person 实例,这个时候只是在程序中有了,但是数据库中还没有
第三行对该实例调用save方法,才会存储数据到数据库中。
2 - 查(Select)——查找数据
查找是个很复杂功能,这里只介绍一点基础的方法,详细的会在本章下一节展开讲讲。
- 使用
Model.objects.get(id=...),通过id查询Model表数据,其中Model是对应的模型名,该方法返回一个实例对象,查询不到会报错。
示例如下(承接上文命令行中代码)
>>> p = Person.objects.get(id=1)
>>> p
<Person: Person object (1)>
>>> p.name
'Big Shuang'
>>> p.sex
'male'
>>> p.age
24
- 使用
Model.objects.all()获取Model表所有数据,
其中Model是对应的模型名,该方法返回一个QuerySet对象,该对象也会在下一节展开讲。
QuerySet对象可使用遍历和切片操作。
示例如下(承接上文命令行中代码)
>>> persons = Person.objects.all()
>>> p = persons[0]
>>> p.name
'Big Shuang'
>>> p.sex
'male'
>>> p.age
24
3 - 改(Update)——修改数据
Django里面,修改数据很简单,修改一下模型实例的属性就可以,然后调用save方法同步到数据库表即可。
示例如下(承接上文命令行中代码)
>>> p = Person.objects.get(id=1)
>>> p.name = "Li hua"
>>> p.save()
执行后数据库表Person内容更新如下
| id | name | sex | age |
|---|---|---|---|
| 1 | Li hua | male | 24 |
4 - 删(Delete)——删除数据
删除数据也很简单。
模型实例调用delete方法即可删除数据,
同时不止模型实例可以调用delete方法,本文第二部分提到的QuerySet也可以调用delete方法删除QuerySet中所有行的数据。
简单示例如下(承接上文命令行中代码)
>>> p = Person.objects.get(id=1)
>>> p.delete()
(1, {'myapp.Person': 1})
执行后数据库表Person中对应的数据将被删除。
Django笔记&教程 5-1 基础增删查改的更多相关文章
- hibernate基础增删查改简单实例
hibernate 基础理论知识网上很多,可以百度和google.这里不做多的介绍,以一个User表来开展例子 建一个web-project 我这里用了junit单元测试环境来进行增删查改的测试,别的 ...
- Django学习笔记009-django models进行数据库增删查改
引入models的定义 from app.models import myclass class myclass(): aa = models. CharField (max_length=No ...
- mysql入门基础增删查改
数据查询语法(DQL) DQL就是数据查询语言,数据库执行DQL语句不会对数据进行改变,而是让数据库发送结果集给客户端. 语法: SELECT selection_list /*要查询的列名称*/ F ...
- Django实现数据库中表格的增删查改
1.urls.py """Django_demo1 URL Configuration The `urlpatterns` list routes URLs to vie ...
- django与mysql实现简单的增删查改
模型定义 from django.db import models class Grades(models.Model): g_name = models.CharField(max_length=2 ...
- php学习笔记:对文件的增删查改等操作
文件的创建: 采用touch()函数,当文件不存在会被创建 例如: <?php header("Content-type: text/html; charset=utf-8" ...
- Yii框架基础增删查改
返回一条数据 Country::find()->one(); 返回所有数据 Country::find()->all(); 返回记录的数量 $country =Country::find( ...
- Dapper基础增删查改、事务和存储过程
1.前言 Dapper是一个轻量级的orm框架,上手也非常的简单,它可以实体映射,所以先准备实体如下: public class Couser { public int id { get; set; ...
- Django笔记&教程 总目录
本篇博客只有目录,正文内容在目录章节链接的博客里 除目录本身外,没有链接的章节,说明内容还没开始编辑 本项目笔记仍在不断创作中,还有些内容会根据自身所学不断更新完善 本项目主要为markdwon文档, ...
随机推荐
- redis无法连接
Exception in thread "main" redis.clients.jedis.exceptions.JedisDataException: DENIED Redi ...
- JavaWeb#JSP内置对象
[1.JSP内置对象简介] 内置对象:不加声明就可以在JSP页面脚本中使用的成员变量.(使用这些对象可以更容易收集客户端发送的请求信息,响应客户端的请求及存储客户信息.) 主要介绍:out,reque ...
- Unity——FSM有限状态机
FSM有限状态机 一.设计思路 1.共同的状态父类,提供可重写的进入,保持,退出该状态的生命周期方法: 2.状态机,管理所有状态(增删查改),状态机运行方法(Run): 3.在角色控制器中,实例化状态 ...
- 如何迁移 Spring Boot 到函数计算
作者 | 田小单 首先介绍下在本文出现的几个比较重要的概念: 函数计算(Function Compute): 函数计算是一个事件驱动的服务,通过函数计算,用户无需管理服务器等运行情况,只需编写代码并上 ...
- 开发函数计算的正确姿势——OCR 服务
作者 | 杜万(倚贤) 阿里云技术专家 简介 首先介绍下在本文出现的几个比较重要的概念: OCR(光学字符识别):光学字符识别(Optical Character Recognition, OCR)是 ...
- Apache ShardingSphere:由开源驱动的分布式数据库中间件生态
2021 年 7 月 21 日 2021 亚马逊云科技中国峰会现场,SphereEx 联合创始人.Apache ShardingSphere PMC 潘娟受邀参与此次峰会,以<Apache Sh ...
- ArcToolbox工具箱
3D Analyst 工具 Data Interoperability Tools Geostatistical Analyst 工具 Network Analyst 工具 Schematics 工具 ...
- Geostatistical Analyst Tools(Geostatistical Analyst 工具)
Geostatistical Analyst 工具 1.使用地统计图层 # Process: GA 图层至格网 arcpy.GALayerToGrid_ga("", 输出表面栅格, ...
- NOIP模拟76
前言 还有不到 10 天就要 CSP-S ...马上我就要有我的第一篇游记了. 今天考试莽了一回,整了大概 2.5h 的 T1 ,可能是因为今天题目比较难,看起来成效不错. 以后还是要注意时间的分配( ...
- 题解 [NOI2014]购票
题目传送门 题目大意 有一个 \(n\) 个点的树,每个点有三个值 \(p_u,q_u,l_u\) ,现在可以从 \(u\) 走到点 \(v\) 当且仅当 \(v\) 是 \(u\) 的祖先并且 \( ...