使用Django框架中ORM系统实现对数据库数据增删改查

 更新时间:2021年09月04日 17:23:45   作者:孤寒者  
这篇文章主要介绍了使用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("修改数据成功!")

以上就是使用Django的ORM实现对数据库数据增删改查方法的详细内容,更多关于Django中实现ORM对数据库操作的资料请关注脚本之家其它相关文章!

相关文章

  • 如何基于python操作json文件获取内容

    如何基于python操作json文件获取内容

    这篇文章主要介绍了如何基于python操作json文件获取内容,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-12-12
  • pycharm指定python路径过程详解

    pycharm指定python路径过程详解

    这篇文章主要介绍了Pycharm指定python路径过程图解,文中通过示例代码介绍的非常详细,对大家的学习具有一定的参考学习价值,需要的朋友可以参考下
    2023-04-04
  • Python中class内置方法__init__与__new__作用与区别解析

    Python中class内置方法__init__与__new__作用与区别解析

    这篇文章主要介绍了Python中class内置方法__init__与__new__作用与区别探究,本文中涉及的类均为Python3中默认的新式类,对应Python2中则为显式继承了object的class,因为未继承object基类的旧式类并没有这些内置方法,需要的朋友可以参考下
    2022-09-09
  • matlab、python中矩阵的互相导入导出方式

    matlab、python中矩阵的互相导入导出方式

    这篇文章主要介绍了matlab、python中矩阵的互相导入导出方式,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-06-06
  • Pandas实现groupby分组统计的实践

    Pandas实现groupby分组统计的实践

    本文主要介绍了Pandas实现groupby分组统计的实践,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-01-01
  • Python pyinstaller库的安装配置教程分享

    Python pyinstaller库的安装配置教程分享

    pyinstaller模块主要用于python代码打包成exe程序直接使用,这样在其它电脑上即使没有python环境也是可以运行的。本文就来和大家分享一下pyinstaller库的安装配置教程,希望对大家有所帮助
    2023-04-04
  • Python求解正态分布置信区间教程

    Python求解正态分布置信区间教程

    今天小编就为大家分享一篇Python求解正态分布置信区间教程,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-11-11
  • python深度学习tensorflow卷积层示例教程

    python深度学习tensorflow卷积层示例教程

    这篇文章主要为大家介绍了python深度学习tensorflow卷积层示例教程,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-06-06
  • Django drf请求模块源码解析

    Django drf请求模块源码解析

    APIView中的dispatch是整个请求生命过程的核心方法,包含了请求模块,权限验证,异常模块和响应模块,我们先来介绍请求模块,对Django drf请求模块源码相关知识感兴趣的朋友一起看看吧
    2021-06-06
  • 100 个 Python 小例子(练习题一)

    100 个 Python 小例子(练习题一)

    这篇文章主要介绍 Python 小例子,有数字组合、个税计算、完全平方数、三数排序、斐波那契数列、copy、九九乘法表、暂停一秒输出等多个实例,需要的朋友可以参考一下
    2021-10-10

最新评论