ORM对数据库增删改查的操作怎么实现
Admin 2022-07-08 群英技术资讯 545 次浏览
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("插入数据成功!")
实现效果:
(注意:分配一下路由,要访问到此视图才会执行!)
控制查询的数据显示的格式(即显示模型的简单表示)
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)
进行查询:
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变成列表.
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("删除数据成功!")
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("修改数据成功!")
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
什么是转义字符在 HTML 中 <、>、& 等字符有特殊含义(<,> 用于标签中,& 用于转义),他们不能在 HTML 代码中直接使用,如果要在
本文主要介绍了PyTorch 使用torchvision进行图片数据增广,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
这篇博客将学习如何使用霍夫圆变换在图像中找到圆圈,OpenCV使用cv2.HoughCircles()实现霍夫圆变换。内容详细,逻辑清晰,有需要的朋友可以参考,希望大家阅读完这篇文章后能有所收获,那么下面就一起来了解一下吧。
Bagging算法(Bootstrap aggregating,引导聚集算法),又称装袋算法,是机器学习领域的一种团体学习算法。最初由Leo Breiman于1996年提出。Bagging算法可与其他分类、回归算法结合,提高其准确率、稳定性的同时,通过降低结果的方差,避免过拟合的发生
猜拳游戏:跟电脑玩石头,剪刀,布游戏。赢了就提示:赢了,你好厉害哦,下一把我一定要赢你。输了就提示:输了,不要走,洗洗手接着来,决战到天亮
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008