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

作者:孤寒者 时间:2024-01-28 03:25:50 

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("插入数据成功!")

实现效果:
(注意:分配一下路由,要访问到此视图才会执行!)

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

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

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报错!而且如果查询不到也会报错!

实现效果:

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

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

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

标签:Django,ORM,数据库,增删改查
0
投稿

猜你喜欢

  • vue更多筛选项小组件使用详解

    2023-07-02 17:06:01
  • Go语言程序开发gRPC服务

    2024-04-23 09:38:02
  • Linux安装Python3.8.1的教程详解

    2022-03-26 10:43:24
  • python中enumerate() 与zip()函数的使用比较实例分析

    2021-02-27 15:00:26
  • Python操作Redis之设置key的过期时间实例代码

    2022-02-11 06:13:05
  • 利用脚本自动安装SQLServer的实现步骤分析

    2024-01-22 20:02:11
  • 深入JDBC sqlserver连接写法的详解

    2024-01-19 12:47:28
  • 详解Python的Twisted框架中reactor事件管理器的用法

    2023-09-07 16:28:18
  • 利用Pycharm断点调试Python程序的方法

    2023-07-05 03:47:08
  • 语义化的label?

    2009-02-11 12:44:00
  • MySQL6.0新增特性

    2010-03-25 10:08:00
  • MySQL 导出数据为csv格式的方法

    2024-01-26 04:52:57
  • NopCommerce架构分析之(六)自定义RazorViewEngine和WebViewPage

    2024-05-03 15:31:10
  • python实现单线程多任务非阻塞TCP服务端

    2021-05-29 07:26:52
  • Pytorch 如何实现常用正则化

    2022-11-02 22:15:14
  • Golang设计模式之单例模式详细讲解

    2024-02-20 01:10:16
  • Python基于Tkinter实现的垃圾分类答题软件代码

    2023-09-09 02:20:24
  • 在Python中使用Mako模版库的简单教程

    2021-11-08 12:33:45
  • python中的format是什么意思,format怎么用

    2022-07-31 08:51:45
  • 对numpy中向量式三目运算符详解

    2023-06-28 02:14:55
  • asp之家 网络编程 m.aspxhome.com