zoukankan      html  css  js  c++  java
  • orm单表操作

    1.增加数据

    from app import models
    //方式一
    book=models.Book.objects.create(name='红楼梦',price=23.8,publish='人民出版社',author='曹雪芹',create_data='2018-09-17')
    //方式二
    book=models.Book(name='水浒传',price=99.8,publish='老男孩出版社',author='施耐庵',create_data='2018-08-08')
    book.save()
    

    2.删除数据

    from app import models
    //方式一
    ret=models.Book.objects.filter(name='西游记').delete()
    //方式二
    ret = models.Book.objects.filter(name='西游记').first()
    ret.delete()
    

    3.修改数据

    ret=models.Book.objects.filter(name='西游记').update(price=20.9)
    #对象修改(没有update方法,但是可以用save来修改)
    book = models.Book.objects.filter(name='西游记').first()
    book.price=89
    book.save()
    

    4.查询数据

    <1> all(): 查询所有结果
    models.Book.objects.all()
    
    <2> filter(**kwargs): 它包含了与所给筛选条件相匹配的对象(与SQL语句中的where很像)
    models.Book.objects.filter(name='西游记').first()
    
    <3> get(**kwargs): 返回与所给筛选条件相匹配的对象,返回结果有且只有一个,如果符合筛选条件的对象超过一个或者没有都会抛出错误。
    ret=models.Book.objects.get(name='红楼梦')
    ret=models.Book.objects.get(id=1)
    
    <4> exclude(**kwargs): 它包含了与所给筛选条件不匹配的对象
    msg = models.Book.objects.filter(name='龙珠').exists()
    
    <5> order_by(*field): 对查询结果排序('-id')
    ret=models.Book.objects.all().order_by('price').filter(name='西游记')
    
    <6> reverse(): 对查询结果反向排序
    ret=models.Book.objects.all().order_by('price'). reverse().filter(name='西游记')
    
    <7> count(): 返回数据库中匹配查询(QuerySet)的对象数量。
    ret=models.Book.objects.all().count()
    
    <8> first(): 返回第一条记录
    msg = models.Book.objects.filter(name='三国').first()
    
    <9> last(): 返回最后一条记录
    msg = models.Book.objects.filter(name='三国').last()
    
    <10> exists(): 如果QuerySet包含数据,就返回True,否则返回False
     msg = models.Book.objects.filter(name='龙珠').exists()
    
    <11> values(*field): 返回一个ValueQuerySet——一个特殊的QuerySet,运行后得到的并不是一系列model的实例化对象,而是一个可迭代的字典序列
    ret=models.Book.objects.all().values('name').distinct()
    
    <12> values_list(*field): 它与values()非常相似,它返回的是一个元组序列,values返回的是一个字典序列
    <13> distinct(): 从返回结果中剔除重复纪录

    5.模糊查询数据

    1.大于price__gt(查询价格大于89 的书)
    ret=models.Book.objects.filter(price__gt='89')
    
    2.小于price__lt(查询价格小于89 的书)
    ret=models.Book.objects.filter(price__lt='89')
    
    3.小于等于price__lte
    ret=models.Book.objects.filter(price__lte='89')
    
    4.大于等于price__gte
    ret = models.Book.objects.filter(price__gte='89')
    
    5.在某个列表中__in
    ret=models.Book.objects.filter(price__in=['23.8','89','100'])
    
    6.在某个范围中__range
    ret=models.Book.objects.filter(price__range=[50,100])
    
    7.查询名字有'红'的书 __contains (类似于SQL中的"%红%")
    ret=models.Book.objects.filter(name__contains='红')
    
    8.查询名字带p的书,忽略大小写 __icontains
    ret=models.Book.objects.filter(name__icontains='P')
    
    9.以XX开头 __startswith
    ret=models.Book.objects.filter(name__startswith='红')
    
    10.以XX结尾 __endswith
    ret=models.Book.objects.filter(name__endswith='梦')
    
    11.按年查询 __year
    ret=models.Book.objects.filter(create_data__year='2017')
    
  • 相关阅读:
    MongoDB数据库学习总结
    windows及linux环境下永久修改pip镜像源的方法
    enumerate枚举函数
    sum求和函数
    zip拉链函数
    python实现面对面快传
    redis实现发布订阅
    python自定义classmethod
    Nginx为什么支持那么高的并发量?
    java进阶(28)--Map集合
  • 原文地址:https://www.cnblogs.com/jianhaozhou/p/9948913.html
Copyright © 2011-2022 走看看