温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

怎么用Django框架中的ORM系统对数据库数据进行增删改查

发布时间:2021-09-06 13:01:08 来源:亿速云 阅读:201 作者:chen 栏目:开发技术

这篇文章主要讲解了“怎么用Django框架中的ORM系统对数据库数据进行增删改查”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么用Django框架中的ORM系统对数据库数据进行增删改查”吧!

目录
  • 1.数据的增删改查----------增加数据

    • 在视图函数中导入User模型类,然后使用下面的方法添加数据:

  • 2.数据的增删改查----------查找数据

    • 这时在定义模型类时定义的__str__()方法的作用就表现了出来

    • User模型类导入

  • 3.数据的增删改查----------删除数据

    • 4.数据的增删改查----------修改数据

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

      感谢各位的阅读,以上就是“怎么用Django框架中的ORM系统对数据库数据进行增删改查”的内容了,经过本文的学习后,相信大家对怎么用Django框架中的ORM系统对数据库数据进行增删改查这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!

      向AI问一下细节

      免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

      AI