首页 编程教程正文

django 单表操作实例详解

piaodoo 编程教程 2020-02-02 12:00:19 857 0 python教程

这篇文章主要介绍了django 单表操作实例详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

前面视图层,模板层、路由层都写了大概,项目肯定是会和数据库打交道,那就讲讲orm的单表查询吧,直接写过一点点,不太全面。

1、项目刚创建好,我们需要在settings里配置一下(用mysql数据库),配置好了,再去app文件夹里的__init__配置下,其实在
哪个__init__配置都一样,项目启动时,首先是执行__init__文件。下面直接贴代码了。

setting文件里:

    DATABASES = {
    'default': {
      'ENGINE': 'django.db.backends.mysql',
      'HOST': '127.0.0.1',
      'PORT': 3306,
      'USER': 'root',
      'PASSWORD': '',
      'NAME': 'zhuyu',
      }
    }

__init__文件里:

    import pymysql
    pymysql.install_as_MySQLdb()
 
    #还是写写为什么吧,前面也写过,再写一次。
    #首先django里mysql用的是MySQLdb,但是python3.x现在不支持MySQLdb了,所引在项目启动时,将MySQLdb转成pymysql
    #你是python2.x的可以不用写。

2、上面的配置配置好了,你就可以在models.py写orm了,我以Student为例

  class Student(model.Model):
    id = models.AutoField(primary_key=True)
    name = models.CharField(max_length=32)
    age = models.CharField(max_length=32)
    balance = models.CharField(max_length=32)

3、数据库迁移命令我就不写了,对数据库操作无非就是增删改查

增加:

方式一:

    ret = models.Student.object.create(name='zhuyu',age=21,balance='5000')
    #这里的ret是学生对象

方式二:

    zhanghao = models.Student(name='zhanghao',age=22,balance='4000)
    zhanghao.save()
    #先实例一个学生对象,再调用学生对象的方法,我们没写,调用的肯定是它基类的方法。

修改:

方式一:

    ret = models.Student.object.filter(name='zhuyu').update(balance='9999)
    #返回值ret是对数据库影响的行数,
    #a = models.Student.object.filter(name='zhuyu'),a是一个queryset对象,所以update是它的一个方法

方式二:

那么我Student对象有没有update方法呢?

ret = models.Student.object.filter(name='zhuyu').first().update(balance='9999')

答案是会报错的!!!!!,记住对象是没有update方法的!!!!!

那我对象怎么修改呢?

    ret = models.Student.object.filter(name='zhuyu').first()
    ret.balance = '8888'
    ret.save()
    #很简单,拿到修改对象,该属性值,调用save()方法就行

删除:

    ret = models.Student.object.filter(name='zhuyu')
    ret.delete()
    #这里的ret是queryset对象,调用的是它的delete方法

继续上面的方法,对象有没有delete方法呢?

    ret = models.Student.object.filter(name='zhuyu').first()
    ret.delete()
    #ret就是学生对象了,结果显示能成功删除!所以对象是有delete方法

增删改上面就写完了,下面主要写写查询吧。
1、all 查询所有的结果:

    ret = models.Student.object.all()
    #ret是queryset对象


2、filter 筛选符合条件的:

    ret = models.Student.object.filter(name='zhuyu')
    # ret为queryset对象,姑且就是一个列表吧,装着一个一个对象

3、first 查询符合条件的第一个对象

    ret = models.Student.object.filter(balance='5000').first()
    # ret没啥好说的,一个对象,上面写了queryset对象姑且为列表,那么就可以索引取值了,
    # 我们再看first()方法,它是取了queryset对象的索引0最为返回值,那么我也可以取
    ret = models.Student.object.filter(balance='5000')[0]
    # 注意:是可以通过索引取值,但是索引不能为负数!!

4、last 查询符合条件的最后一个对象

    ret = models.Student.object.filter(balance='2000').last()
    # ret是学生对象,前面不是说queryset对象是不能取负数嘛,那最后一个用-1
    # 肯定会报错,那么last怎么实现的呢?
    # reverse查询的结果进行反转,看下面这句代码
    ret = models.Student.object.filter(balance='2000').reverse().first()
    # last()原理就是这样实现的

5、exclude 筛选出不符合条件的

    ret = models.Student.object.exclude(age=20)
    # ret 为queryset对象
    # exclude和filter一样,可以跟多个条件,用逗号分开
    ret = models.Student.object.exclude(age=20,name='zhuyu')
    # 查询出不是name为朱宇,并且年龄为20的所有学生,相当于and

6、count 查看queryset对象里的个数

    ret = models.Student.object.all()
    # ret为一个整型

7、order_by 排序

    # 以学生年龄从小到大排序
    ret = models.Student.object.order_by('age')
    # ret为queryset对象
    # 以学生年龄从大到小排序
    ret = models.Student.object.order_by('-age')
    # 我认为实现方法为,先取出一个条件(也就是字符串),取索引0,看是否为'-',是的话
    # 取索引1到最后为条件,再转换sql语句时,ASC改为DESC,排序方式改变。

8、reverse 结果取反

    ret = models.Student.object.order_by('age').reverse()
    # ret为queryset对象,年龄从大到小排序。

9、exists 判断queryset对象里是否有数据嘛

它的返回值就是True False

10、values和values_list

values:它是queryset对象的方法,它的返回值也是queryset对象,里面是一个大列表装着一个一个字典

字典里的key就是values里的值

values_list:queryset对象的方法,它的返回值也是queryset对象,里面是一个大列表一个一个元组,元组的值就是values_list里所取到的值。

11、distinct 去重,不用多说了,queryset对象的方法。

12、get 也是取出符合条件的一个,但是那个条件必须是唯一的,必须存在的。

假如:取出叫zhuyu的学生,叫zhuyu的学生不止一个,那么你用get就会报错取出叫dsb的学生,如果没有,你用get就会出错。

上面就是一些单表查询的方法,发现没有,为何每个返回值,我都要写什么类型,大多数就是queryset类型,所以只要前面
是queryset对象,我们都可以用到它的方法,比如:取出学生balance为5000,且按照年龄从小到大排序。

下面写写基于双下划线的模糊查询

  # 查询学生年龄为12,16,13的学生
  models.Student.object.filter(age__in=[13,13,16])
 
  # 查询学生年龄大于12的学生
  models.Student.object.filter(age__gt=12)
 
  # 查询学生年龄小于12的学生
  models.Student.object.filter(age__lt=12)
 
  # 查询学生年龄大于等于12的学生
  models.Student.object.filter(age__gte=12)
 
  # 查询学生年龄小于等于12的学生
  models.Student.object.filter(age__lte=12)
 
  # 查询学生名字中有宇的学生
  models.Student.object.filter(name__contains='宇')
 
  # 查询学生名字以朱开头的学生
  models.Student.object.filter(name__startswith='朱')

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

版权声明:

本站所有资源均为站长或网友整理自互联网或站长购买自互联网,站长无法分辨资源版权出自何处,所以不承担任何版权以及其他问题带来的法律责任,如有侵权或者其他问题请联系站长删除!站长QQ754403226 谢谢。

有关影视版权:本站只供百度云网盘资源,版权均属于影片公司所有,请在下载后24小时删除,切勿用于商业用途。本站所有资源信息均从互联网搜索而来,本站不对显示的内容承担责任,如您认为本站页面信息侵犯了您的权益,请附上版权证明邮件告知【754403226@qq.com】,在收到邮件后72小时内删除。本文链接:http://www.piaodoo.com/868.html

评论

搜索

游戏网站源码,织梦网站源码,wordpress,wordpress主题,wordpress下载,wordpress插件,wordpress.com,wordpress模板,wordpress教程,wordpress 主题,wordpress安装,wordpress 模板,wordpress 插件,wordpress主题下载,wordpress企业主题,wordpress seo,wordpress主题开发,wordpress theme,wordpress论坛,wordpress 企业主题,wordpress主机,wordpress中文主题,wordpress cms主题,wordpress plugin,wordpress 主题下载,wordpress 主机,wordpress空间,wordpress mu,wordpress 模版,wordpress汉化主题,wordpress淘宝客主题,wordpress 空间,wordpress代码,WORDPRESS HOSTING,wordpress优点,wordpress安卓客户端,wordpress技巧,wordpress换空间,wordpress themes,网站模板,ppt模板网站,模板网站,企业网站模板,网站设计模板,免费网站模板,个人网站模板,ppt模板下载网站,网站模板下载,公司网站模板,门户网站模板,学校网站模板,网站首页模板,网站模板免费下载,旅游网站模板,网站后台模板,免费网站模板下载,传奇网站模板,网站建设模板,外贸网站模板,网站 模板,个人主页网站模板,个人网站模板下载,政府网站模板,音乐网站模板,导航网站模板,免费企业网站模板,企业网站模板下载,手表网站模板,韩国网站模板,汽车网站模板,教育网站模板,网站后台管理模板,班级网站模板,新闻网站模板,房产中介网站模板,旅游网站模板下载,工艺品网站模板,电子商务网站模板,旅游网站设计模板,团购网站模板,flash网站模板,个人网站设计模板,婚庆网站模板,广告公司网站模板,商业网站模板,手机网站模板,免费模板网站推荐,ppt免费模板网站推荐,织梦网站模板,html网站模板建站,网站html模板,免费个人网站模板,公司网站源码,sns源码,彩票网站源码,周易网站源码,源码基地,交友源码,学校网站源码,asp.net 源码,源码天下,jsp网站源码,论坛源码下载,广告联盟源码,建站源码,delphi源码,源码爱好者,酷源码,net源码,源码超市,医疗网站源码,flash源码,搜源码,源码程序,dede源码,新闻网站源码,易语言源码大全,旅游网站源码下载,flash 源码,免费源码论坛,android游戏源码,电脑维修网站源码,30源码网,股票软件源码,卖源码,源码教程,安居客 源码,vip源码,家教源码,.net源码下载,Web源码,网络公司源码,佛教网站源码,android源码学习,房产源码,钓鱼网站源码,775源码屋,web游戏源码,成品网站 源码78w78不用下载,h5游戏网站源码,asp网站源码下载,webgame源码,电子商务网站源码,vb.net源码,乐嘿源码,8a商业源码论坛,fbreader源码,在线客服系统 源码,google源码,.net网站源码,快递查询源码,源码搜藏网,dede整站源码,周易 源码,52源码论坛,财经网站源码,织梦下载站源码,qq钓鱼网站源码,flash游戏源码,房产网源码,源码搜搜,电子商务源码,团购网站源码,团购网源码,jsp源码下载,jsp源码,h站源码,8a源码,婚纱摄影网站源码,易语言盗号源码,x站源码,qq空间psd源码,免费商业源码,笑话网站源码,源码集合,源码家园,啊哦源码,星期六源码,源码熊,阿奇源码,百分百源码网,一手日源码资源,旅行网站源码,b站工程源码泄露,新站长源码,8a商业源码,asp论坛源码,flash源码下载,404源码社区,创业网站源码,php网页源码,易支付源码,成品网站w灬源码,免费CMS成品网站源码,成品网站W灬源码1688仙踪林,成品APP短视频源码下载网站,成品网站源码1688可靠吗,免费B2B网站源码,成品APP直播源码下载,国外儿童网站源码在线,成品网站W灬源码1688,源码,成品网站w灬 源码1688,免费源码网站都有哪些,成品网站源码78W78隐藏通道1,网站源码,源码网,源码网站,源码时代,源码之家,源码下载,php源码,易语言源码,源码论坛,源码是什么,商城源码,论坛源码,源码交易,源码站,源码库,免费源码,免费网站ja**源码大全,ja**源码,成品网站w灬源码1377,a5源码,站长源码,成品网站源码78W78隐藏通道1APP,源码分享,网站源码下载,源码中国,asp源码,源码社区,企业网站源码,php源码下载,成品app直播源码搭建,在线观看视频网站源码2021,旅游网站源码,安卓源码,通达信选股公式源码,神马影院php源码,c#源码,成品网站w灬源码1688网页,php 源码,网页游戏源码,android源码下载,源码吧,视频源码大全,成品短视频APP源码搭建,asp源码下载,私服源码,电脑维修源码,个人主页源码,源码出售,php网站源码,刀客源码,网址导航源码,导航网站源码,源码天空,asp 源码,软件源码,精品源码,成品网站源码1688自动跳转,个人网站源码,源码哥,在线考试系统源码,cms源码,c# 源码,商业源码,vb源码,门户网站源码,音乐网站源码,中国源码,安卓源码下载,asp网站源码,在线客服源码,电影网站源码,免费源码下载,整站源码,源码交易网,易语言源码网,.net源码,在线客服系统源码,淘客源码,卡盟源码,网站源码出售,vb源码下载,莎莎源码,熊猫烧香源码,asp.net源码,商业源码网,外贸网站源码,61源码网,zblog模板,zblog企业模板,帝国cms模板,帝国cms插件,discuz模板