django模型(增删改查等)
2018-04-04 10:48 _天枢 阅读(266) 评论(0) 编辑 收藏 举报Django提供的模型操作起来数据库非常方便
以自定义模型名字Demo为例:
获取所有数据:all()
demo.objects.all() #返回queryset对象 #这个语句和Select * from demo还是有一定区别的 demo.objects.all() 是直接获取所有列,速度上比select要快
单个精确查找数据:get()
demo.objects.get(name='qc') #一般精确找一条数据用get,需要注意的是,如果查找的数据不存在,或者,有多个数据会报异常。
过滤,精确查找:filter()
相对来说,filter的用法就比较多了,排序,精确查找等
例1:条件
demo.objects.filter(name='qc') #返回的是一个list对象 #相当于sql语句 select * from demo whert name='qc';
例2:多个条件组合
demo.objects.filter(name='qc',id=3) #相当于sql语句 select * from demo where name='qc' and id =3;
例3:__双下划线
demo.objects.filter(id__lte=3) #注意这里两个下划线__lte 相当于sql语句: select * from demo where id <= 3;
demo.objects.filter(name__contains='qc')
相当于sql语句:
select * from demo where name like '%qc%'
例4:排序
demo.objects.order_by("name") 相当于sql语句: select * from demo order by name; #默认正向排序 也可以降序 demo.objects.order_by("-name") #注意这里有一个减号 相当于sql语句: select * from demo order by name desc;
#在filter基础上排序 demo.objects.filter(name='qc').order_by('name') 相当于sql语句: select * from demo where name='qc' order by name asc;
例5:切片数据
demo.objects.order_by('name')[0] #只取第一条数据 相当于sql语句: select * from demo order by name limit 1; demo.objects.order_by('name')[0:2] #只取2条数据 相当于sql语句: select * from demo order by name offset 0 limit 2;
作 者:
天枢
出 处:
http://www.cnblogs.com/yhleng/
关于作者:专注于软件自动化测试领域。如有问题或建议,请多多赐教!
版权声明:本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文链接。
特此声明:所有评论和私信都会在第一时间回复。也欢迎园子的大大们指正错误,共同进步。或者
直接私信我
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角
【
推荐】
一下。您的鼓励是作者坚持原创和持续写作的最大动力!