使用Django框架中ORM系统实现对数据库数据增删改查
作者:孤寒者 发布时间:2024-01-28 03:25:50
标签:Django,ORM,数据库,增删改查
1.数据的增删改查----------增加数据
在视图函数中导入User模型类,然后使用下面的方法添加数据:
from django.http import HttpResponse
from .models import User
# Create your views here.
def add_user(request):
#方法一
taka = User(name='taka',age=18)
taka.save()
#方法二
xiaopo = User()
xiaopo.name = 'xiaopo'
xiaopo.age = 18
xiaopo.save()
#方法三
aa = User.objects.get_or_create(name='xiaohong',age=18) #插入前会进行查找,如果没有相同的数据就会添加;如果有就不会。
print(aa) #会返回一个元组,第一个数据是添加成功的实例;第二个数据是True或False。(添加成功为True;反之为False)
# 此处打印结果: (<User: name:xiaohong, age:18>, True)
# 插入前会进行查找,如果没有相同的数据就会添加;如果有就不会。 因为上面插入了相同数据,所以此处不会插入数据。
User.objects.get_or_create(name='xiaohong',age=18)
return HttpResponse("插入数据成功!")
实现效果:
(注意:分配一下路由,要访问到此视图才会执行!)
2.数据的增删改查----------查找数据
这时在定义模型类时定义的__str__()方法的作用就表现了出来
控制查询的数据显示的格式(即显示模型的简单表示)
from django.db import models
# Create your models here.
class User(models.Model):
id = models.AutoField(primary_key=True) #主键可以省略,Django默认会为我们加上一个名为id的主键,写的话就可以改主键的名字!
name = models.CharField(max_length=50) # CharField——字符串
age = models.IntegerField() # IntegerField——整数
def __str__(self):
"""
返回模型的字符串表示
我们告诉Django,默认应使用哪个属性来显示有关此模型的信息
Django调用方法__str__()来显示模型的简单表示
"""
return "name:%s, age:%s" %(self.name,self.age)
进行查询:
User模型类导入
from django.http import HttpResponse
from .models import User
def search_user(request):
#查询所有记录对象
rs1 = User.objects.all()
print("这是所有记录对象:",rs1)#通过观察,可以发现查询到的记录对象的输出方式就是模型中的__str__的格式.
# 同时这个查询结果rs1是个queryset对象,是一个类似于列表的对象。具备列表里的一些常用方法,比如:切片[0:3],下标取值rs1[1]...但是下标取值的话不支持反向取值。
#查询一个记录对象
rs2 = User.objects.get(name="xiaopo") # 此方法查询,如果不存在/存在多条都会报错! 所以一般通过id值。
print("这是一个记录对象:",rs2)
#查询满足条件的对象
rs3 = User.objects.filter(name='xiaoming') # 取不到则为空;多条的话都可以取到
print("这是满足条件的对象:",rs3)
return HttpResponse("查询数据成功!")
注意:
1.all()和filter()方法返回的是QuerySet对象,查询不到则为空(但咋样都不会报错,就很牛!)。
2.get()方式返回的单个对象,如果符合条件的对象有多个,则get报错!而且如果查询不到也会报错!
实现效果:
3.拓展——关于QuerySet简单整两句:
从数据库中查询出来的结果一般是一个集合,这个集合叫做 QuerySet(是一个类似于列表的对象,具备列表里的一些常用方法,比如:切片[0:3],下标取值rs1[1]…但是下标取值的话不支持反向取值).QuerySet是可迭代对象.QuerySet支持切片, 不支持负索引.可以用list强行将QuerySet变成列表.
3.数据的增删改查----------删除数据
from django.http import HttpResponse
from .models import User
def delete_user(request):
#实例和QuerySet对象都具备删除方法!
User.objects.get(id=1).delete()#get方法得到的是单个对象(一个实例对象),所以是删除一条数据!
User.objects.filter(age=18).delete()#删除所有age属性值为18的数据!
User.objects.all().delete()#删除所有数据!
s = User.objects.filter(age=18)
s[1].delete()#删除age值为18的数据中指定的一条
return HttpResponse("删除数据成功!")
4.数据的增删改查----------修改数据
from django.http import HttpResponse
from .models import User
def update_user(request):
#第一种方法:先查找到数据,然后再进行属性赋值修改(对于实例的修改)
rs = User.objects.get(name="xiaoming")#修改name属性值为xiaoming的name属性值为xiaowang(因为使用了get方法所以仅修改第一条!)
rs.name='xiaowang'
rs.save()
#第二种方法:使用update方法直接修改(对于集合的修改,只能用于QuerySet对象)
User.objects.filter(name='xiaowang').update(name='AAA')#修改所有name属性值为xiaowang的name属性值为AAA!
User.objects.all().update(age=22)#修改所有数据的age属性值为22!
return HttpResponse("修改数据成功!")
来源:https://gu-han-zhe.blog.csdn.net/article/details/119982764


猜你喜欢
- 守来说,AJAX在现在是热得不能再热的技术。没有人能否认,它拥有大批的支持者。在CNN上,它从二月份的一个不被看好的词语到十月份成长成一个初
- 一、python代码实现及turtle库简单介绍桌面时钟项目描述1、使用turtle库绘制时钟外形及表针;2、使用datetime获取系统时
- 主要应用了argsort()函数,函数原型:numpy.argsort(a, axis=-1, kind='quicksort
- 发现问题写python的时候出现了这个错,然后网上的教程的解决方案几乎都是——“重新定义下这个变量”,看的我一脸懵逼后来发现原来是我把ret
- 对python中的控制条件、循环和跳出详解代码缩进(代码块):python用缩进表示代码块,没有其他语言的大括号缩进是强制检查,整个代码缩进
- base64 其实是一种编码转换方式, 将 ASCII 字符转换成普通文本, 是网络上最常见的用于传输8Bit字节代码的编码方式之一。bas
- 说明C# 调用 Python 程序有多种方式,本篇用的是第 4 种:nuget的ironPython;用 c/c++ 调用python,再封
- 首先,FSO是FileSystemObject的简称。当然也就是我们的俗称FSO组件了,该组件可以用来处理驱动器、文件夹以及文件。它可以检测
- 在项目文件中新建文件.env .env.pro 两个文件其中.env 是默认设置 .env.pro 为正式环境设置1、设置.env中的内容信
- 一:C# 连接SQL数据库 Data Source=myServerAddress;Initial Catalog=
- 前言数学建模的介绍与作用全国大学生数学建模竞赛:全国大学生数学建模竞赛创办于1992年,每年一届,已成为全国高校规模最大的基础性学科竞赛,也
- SQLServer中的批量注释批量注释Ctrl + (K,C):按住Ctrl键不放,然后依次按下K和C批量取消注释Ctrl + (K,U):
- 当我们需要通过xml格式处理sql语句时,经常会用到< ,<=,>,>=等符号,但是很容易引起xml格式的错误,这样
- 作者:JavaScript Kit译者:子乌(Sheneyan)翻译日期:2006-02-12英文原文:Conditional Compil
- 人在学校,身不由己。总有一些奇奇怪怪的学习任务,需要我们刷够一定的时长去完成,但这很多都是不太令人感兴趣的文字或是视频,而这些课都有共同的特
- 本文介绍了python十进制和二进制的转换方法(含浮点数),分享给大家,也给自己留个笔记,具体如下:我终于写完了 , 十进制转二进制的小数部
- 获取所有文章数据o := orm.NewOrm()qs := o.QueryTable("Article")12获取总条
- NumPy数组的维数称为秩(rank),一维数组的秩为1,二维数组的秩为2,以此类推。在NumPy中,每一个线性的数组称为是一个轴(axes
- 做一个简单WPF连接数据库的控件类型和名称:DataGrid:dataGrid &
- 1. 原理对于DNA序列,一阶马尔科夫链可以理解为当前碱基的类型仅取决于上一位碱基类型。如图1所示,一条序列的开端(由B开始)可能是A、T、