1.model

假设我们的model如下:

某个JobType下有很多Job。

class JobType(models.Model):
name = models.CharField(max_length=10)
description = models.CharField(max_length=100, null=True, blank=True) def __str__(self):
return self.name
class Job(models.Model):
name = models.CharField(max_length=50)
type = models.ForeignKey(JobType, related_name='jobs')
city = models.CharField(max_length=30)
experience = models.CharField(max_length=15)
education = models.CharField(max_length=10)
salary = models.CharField(max_length=15)
public_time = models.DateTimeField() def __str__(self):
return self.name

2.查询

2.1 查询所有JobType

In [1]: JobType.objects.all()

Out[1]: [<JobType: Java>, <JobType: Python>, <JobType: PHP>]

对上述的queryset按名字排序(逆序则在字段前加减号‘-’,如order_by('-name') )

In [2]: JobType.objects.all().order_by('name')

Out[2]: [<JobType: Java>, <JobType: PHP>, <JobType: Python>]

2.2 查询name为‘Python’的JobType( 注意用get()方法得到的是单个对象而不是queryset,若有多个对象满足条件应该使用filter()方法。 )

In [3]: JobType.objects.get(name='Python')

Out[3]: <JobType: Python>

注意:1)若get()返回多个对象,会引发异常 MultipleObjectsReturned

2)若没有对象符合查询条件,会引发异常 DoseNotExist,如:

JobType.objects.get(id=100)  # raises JobType.DoesNotExist

2.3 查询所有JobType的name为Python的Job

In [4]: type = JobType.objects.get(name='Python')

In [5]: Job.objects.filter(type=type)

Out[5]: [<Job: Python开发工程师>, <Job: Python开发工程师>, <Job: python软件工程师>, <Job: Python>, <Job: Python开发>, <Job: Python>, <Job: Java/Python>, <Job: 大数据开发工程师JAVA、Scala、Python>, <Job: python开发工程师>, <Job: Python>, <Job: Python研发高级工程师>, <Job: Python开发>, <Job: Python工程师>, <Job: Python>, <Job: Python/PHP 语言开发工程师-YL>, <Job: Python工程师>, <Job: Python工程师(中高级)>, <Job: Python后台开发工程师>, <Job: python web开发实习生>, <Job: Python开发>, '...(remaining elements truncated)...']

由于我们在Job model中定义type外键时,定义了related_name=‘jobs’,故还能用下面的方法查询

In [6]: type = JobType.objects.get(name='Python')

In [7]: type.jobs.all()

Out[7]: [<Job: Python开发工程师>, <Job: Python开发工程师>, <Job: python软件工程师>, <Job: Python>, <Job: Python开发>, <Job: Python>, <Job: Java/Python>, <Job: 大数据开发工程师JAVA、Scala、Python>, <Job: python开发工程师>, <Job: Python>, <Job: Python研发高级工程师>, <Job: Python开发>, <Job: Python工程师>, <Job: Python>, <Job: Python/PHP 语言开发工程师-YL>, <Job: Python工程师>, <Job: Python工程师(中高级)>, <Job: Python后台开发工程师>, <Job: python web开发实习生>, <Job: Python开发>, '...(remaining elements truncated)...']

当然,我们也可以用一条语句完成这个查询。就是下面的跨表查询,即外键 + 两条下划线 + 另一个表的字段:fk__field-in-foreign-model

In [8]: Job.objects.filter(type__name='Python')

Out[8]: [<Job: Python开发工程师>, <Job: Python开发工程师>, <Job: python软件工程师>, <Job: Python>, <Job: Python开发>, <Job: Python>, <Job: Java/Python>, <Job: 大数据开发工程师JAVA、Scala、Python>, <Job: python开发工程师>, <Job: Python>, <Job: Python研发高级工程师>, <Job: Python开发>, <Job: Python工程师>, <Job: Python>, <Job: Python/PHP 语言开发工程师-YL>, <Job: Python工程师>, <Job: Python工程师(中高级)>, <Job: Python后台开发工程师>, <Job: python web开发实习生>, <Job: Python开发>, '...(remaining elements truncated)...']

2.4 查询JobType的name为‘Python’之外的所有Job

In [9]: Job.objects.all().exclude(type__name='Python')

Out[9]: [<Job: PHP/高级PHP工程师>, <Job: PHP开发工程师>, <Job: PHP>, <Job: PHP开发>, <Job: PHP>, <Job: PHP工程师>, <Job: PHP工程师>, <Job: PHP>, <Job: PHP研发工程师>, <Job: PHP开发工程师>, <Job: PHP>, <Job: PHP>, <Job: PHP开发工程师>, <Job: 高级PHP开发工程师>, <Job: PHP高级工程师>]

3.django内置的查询字段

语法为字段 + 两条下划线 + 内置查询字段:field__bulit-in

3.1 gt(gte): 大于(大于等于)

查询id > 2的JobType:

In [9]: JobType.objects.filter(id__gt=2)

Out[9]: [<JobType: PHP>]

相当于sql语句:

SELECT ... WHERE id > 2;

类似的还有 lt(lte): 小于(小于等于)

3.2 in

查询id为1,3的JobType:

In [10]: JobType.objects.filter(id__in=[1,3])

Out[10]: [<JobType: Java>, <JobType: PHP>]

相当于sql语句:

SELECT ... WHERE id IN (1, 3);

3.3 range 常用来筛选出属于某个连续区间的对象

查询id在1~3范围内的所有JobType:

In [11]: JobType.objects.filter(id__range=(1,3))

Out[11]: [<JobType: Java>, <JobType: Python>, <JobType: PHP>]

相当于sql语句:

SELECT ... WHERE id BETWEEN 1 and 3;

3.4 contains 包含‘xxx’(大小写敏感),常用于找出包含某些关键字的对象

查询type名字包含“python”的Job:


In [12]: Job.objects.filter(type__name__contains='python')

Out[12]: []

相当于sql语句:

SELECT ... WHERE name LIKE '%python%';

类似的有icontains (大小写不敏感)注意contains是大小写敏感的,icontains是大小写不敏感的。对比如下:

In [13]: Job.objects.filter(type__name__icontains='python')

Out[13]: [<Job: Python开发工程师>, <Job: Python开发工程师>, <Job: python软件工程师>, <Job: Python>, <Job: Python开发>, <Job: Python>, <Job: Java/Python>, <Job: 大数据开发工程师JAVA、Scala、Python>, <Job: python开发工程师>, <Job: Python>, <Job: Python研发高级工程师>, <Job: Python开发>, <Job: Python工程师>, <Job: Python>, <Job: Python/PHP 语言开发工程师-YL>, <Job: Python工程师>, <Job: Python工程师(中高级)>, <Job: Python后台开发工程师>, <Job: python web开发实习生>, <Job: Python开发>, '...(remaining elements truncated)...']

3.5 startswith 以‘xxx’开头(大小写敏感)

In [14]: Job.objects.filter(name__startswith='高级')

Out[14]: [<Job: 高级python研发工程师>, <Job: 高级Python工程师>, <Job: 高级python开发>, <Job: 高级python工程师>, <Job: 高级python开发>, <Job: 高级python工程师>, <Job: 高级Python工程师>, <Job: 高级Python工程师>, <Job: 高级python开发工程师>, <Job: 高级Python工程师>, <Job: 高级工程师-Python>, <Job: 高级python工程师>, <Job: 高级Python开发工程师>, <Job: 高级Python开发工程师>, <Job: 高级Python开发工程师>, <Job: 高级python工程师>, <Job: 高级Python工程师>, <Job: 高级python开发工程师>, <Job: 高级Python开发工程师>, <Job: 高级python开发工程师>, '...(remaining elements truncated)...']

相当于sql语句:

SELECT ... WHERE name LIKE '高级%';

类似的有istartswith (大小写不敏感)

3.6 endswith 以‘xxx’结尾(大小写敏感)

类似的有iendswith (大小写不敏感)

3.7 regex 正则(大小写敏感)

找出city以‘北京’或者‘上海’开头的Job:

In [15]: Job.objects.filter(city__regex=r'^(上海|北京)')

Out[15]: [<Job: Python开发工程师>, <Job: Python>, <Job: Python开发>, <Job: Python研发高级工程师>, <Job: Python开发>, <Job: Python后台开发工程师>, <Job: python web开发实习生>, <Job: Python开发>, <Job: python实习生>, <Job: python工程师>, <Job: python/django开发工程师>, <Job: python工程师>, <Job: 资深Python开发>, <Job: Python>, <Job: Python工程师/实习生--无人车方向>, <Job: Python>, <Job: python高级工程师>, <Job: Python开发>, <Job: python工程师>, <Job: python开发(校招)>, '...(remaining elements truncated)...']

类似的有iregex (大小写不敏感)

3.8 和DateTime字段相关的内置查询字段

date 使用date类型的值

year 使用整数来表示年份

month 使用整数1~12来表示12个月份

day 使用整数来表示日

week_day 使用整数1~7来表示星期几(其中1为星期日)

hour 使用整数0~23来表示24小时

minute 使用整数0~59来表示分钟

second 使用整数0~59来表示秒钟

比如查询在2017年2月14日之后发布的Job:

Job.objects.filter(public_time__date__gt=datetime.date(2017,2,14))

查询2017年1月份发布的Job:

Job.objects.filter(public_time__year=2017, public_time__month=1)

3.9  isnull  可设置为True或者False,用来筛选某字段 为NULL / 不为NULL 的对象

In [16]: JobType.objects.filter(description__isnull=True)

Out[16]: [<JobType: Java>, <JobType: PHP>]

相当于sql语句:

SELECT ... WHERE description IS NULL;





django-查询语句(一)的更多相关文章

  1. django查询操作

    查询操作是Django的ORM框架中最重要的内容之一.我们建立模型.保存数据为的就是在需要的时候可以查询得到数据.Django自动为所有的模型提供了一套完善.方便.高效的API,一些重要的,我们要背下 ...

  2. Django查询SQL语句

    Django查询SQL语句 # 1 res=models.Book.objects.all() # print(res)#<QuerySet [<Book: Book object> ...

  3. Django查询数据库性能优化

    现在有一张记录用户信息的UserInfo数据表,表中记录了10个用户的姓名,呢称,年龄,工作等信息. models文件 from django.db import models class Job(m ...

  4. django查询数据库无法过滤月份的解决

    我试过,当settings里的:USE_TZ = False时也可以查询,但是数据库里的时间就会显示错的 解决方法是可以再终端输入 mysql_tzinfo_to_sql /usr/share/zon ...

  5. django 查询如何使用 or

    参考:http://stackoverflow.com/questions/6567831/how-to-perform-or-condition-in-django-queryset django自 ...

  6. 关于Django查询知识点总结

    ========关于Django查询知识点总结======= models.Book.objects.filter(**kwargs): querySet [obj1,obj2] models.Boo ...

  7. mysql-数据库查询语句汇总

    目录 数据库查询语句 ***** 添加数据补充: 所有的select 关键字 where 条件 distinct 去除重复记录 指定字段 取别名 group by having order limit ...

  8. SQL Server-简单查询语句,疑惑篇(三)

    前言 对于一些原理性文章园中已有大量的文章尤其是关于索引这一块,我也是花费大量时间去学习,对于了解索引原理对于后续理解查询计划和性能调优有很大的帮助,而我们只是一些内容进行概括和总结,这一节我们开始正 ...

  9. thinkphp中的查询语句

    <?php namespace Admin\Controller; use Think\Controller; class MainController extends Controller { ...

  10. Oracle 查询语句(where,order by ,like,in,distinct)

    select * from production;alter table production add productionprice number(7,2); UPDATE production s ...

随机推荐

  1. 关于浏览器和HTTP协议

    关于浏览器 浏览器的主要功能就是向服务器发出请求,在浏览器窗口中展示想要访问的网络资源.这里资源一般是指 HTML 文档,图片等其他的类型.资源的位置由用户使用 URL(统一资源标示符)指定. 而浏览 ...

  2. php中字符串长度和截取的函数

    在做PHP开发的时候,由于我国的语言环境问题,所以我们常常需要对中文进行处理. 在PHP中,我们都知道有专门的mb_substr和mb_strlen函数,可以对中文进行截取和计算长度,但是,由于这些函 ...

  3. Java解析JSON文件的方法(一)

    一.首先需要在Eclipse工程中导入相关的jar包,jar包参见链接:http://yunpan.alibaba-inc.com/share/link/NdA5b6IFK 二.提供一份待解析的jso ...

  4. bzoj 1036

    1036: [ZJOI2008]树的统计Count Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 11858  Solved: 4803[Submit ...

  5. bug工具

    在线工具:柠檬bug管理--兼顾项目管理 开源工具:PPM Bug 缺陷管理系统 项目管理.bug管理:http://www.bugfree.cn

  6. Linux 线程调度与优先级设置

    转载:http://blog.csdn.net/a_ran/article/details/43759729 线程调度间的上下文切换 什么是上下文切换? 如果主线程是唯一的线程,那么他基本上不会被调度 ...

  7. Eclipse tomcat插件

    1. 下载 http://www.eclipsetotale.com/tomcatPlugin.html 2. 解压 解压到Eclipse_Home/dropins 3. 重启Eclipse

  8. 网站安全配置(Nginx)防止网站被攻击(包括使用了CDN加速之后的配置方法)

    原文链接:http://www.bzfshop.net/article/176.html 网站被攻击是一个永恒不变的话题,网站攻击的方式也是一个永恒不变的老套路.找几百个电脑(肉鸡),控制这些电脑同时 ...

  9. JavaScript 44 Puzzlers

    http://mp.weixin.qq.com/s?__biz=MzAxODE2MjM1MA==&mid=2651550987&idx=1&sn=f7a84b59de14d0b ...

  10. ThinkPHP--IS_AJAX

    增加IS_GET,IS_POST,IS_PUT,IS_DELETE,IS_AJAX常量,方便除控制器外的地方判断方法,Action类的isGet isPost等方法暂时保留,但不建议使用.