67.ORM查询条件:range的使用,使用make_aware将navie time 转换为aware time
模型的定义,models.py文件中示例代码如下:
from django.db import models
# 在定义模型的类时,一定要继承models.Model
class Category(models.Model):
# 设置字段的最大长度为100
name = models.CharField(max_length=100)
# 重新定义该类的一些属性
class Meta:
# 自定义表名
db_table = 'category'
class Article(models.Model):
title = models.CharField(max_length=100)
content = models.TextField()
# 设置删除的时候为级联删除
category = models.ForeignKey('Category', on_delete=models.CASCADE, null=True)
# 设置auto_now_add=True,就会将所有数据的该属性的初始值设置为添加数据时的时间,并且允许为空值
create_time = models.DateTimeField(auto_now_add=True, null=True)
# 重写__str(self)方法
def __str__(self):
return "<(Article: id: %s,title: %s, content: %s)>" % (self.id, self.title, self.content)
# 重新定义该类的一些属性
class Meta:
db_table = 'article'
range:判断某个field的值是否在给定的区间中。示例代码如下:
from .models import Article, Category
from django.http import HttpResponse
from datetime import datetime
def index(request):
# 设置一个开始日期,采用datetime()方法,并且为参数传递相应的值
start_date = datetime(year=2020, month=2, day=5, hour=2)
# 设置一个结束日期
end_date = datetime(year=2020, month=2, day=5, hour=23)
# 使用range查询条件查找在一定时间段的文章
# 为模型所形成的表的字段规定相应的查询条件,可以使用“字段名__查询条件”=‘value’,进行查询
articles = Article.objects.filter(create_time__range=(start_date,end_date))
# 打印出django底层执行的sql语句
print(articles.query)
# 打印出符合时间段的QuerySet对象
print(articles)
return HttpResponse('success !')
查看打印出的结果:
SELECT article.id, article.title, article.content, article.category_id, article.create_time FROM article WHERE article.create_time BETWEEN 2020-02-05 02:00:00 AND 2020-02-05 23:00:00
<QuerySet [<Article: <(Article: id: 1,title: Hello, content: 你好)>>, <Article: <(Article: id: 2,title: Hello World, content: 大家好)>>, <Article: <(Article: id: 3,title: 钢铁是怎样炼成的, content: 你好
)>>, <Article: <(Article: id: 4,title: 中国吸引力, content: 精彩极了)>>]>
此时出现警告信息:RuntimeWarning: DateTimeField Article.create_time received a naive datetime (2020-02-05 23:00:00) while time zone support is active.RuntimeWarning),意思是:模型Article的create_time字段收到了一个navie time(即幼稚的时间,不知道自己处于哪个时区),但是时区支持的是active time(知道自己是哪个时区的时间)。
解决警告信息的操作:在项目的settings.py文件中,将USE_TZ = True设置为True,默认情况下为True;将TIME_ZONE = 'UTC',设置当前所处的时区,或者是你的项目所运行的时区,当前设置为TIME_ZONE = 'Asia/Shanghai'。并且在views.py文件中进行以下修改:
# 从django.utils.timezone模块中导入make_aware()函数
from django.utils.timezone import make_aware
# 执行make_aware()函数将navie time 转换为active time。
start_date = make_aware(datetime(year=2020, month=2, day=5, hour=2))
end_date = make_aware(datetime(year=2020, month=2, day=5, hour=23))
之后再次运行项目:
SELECT article.id, article.title, article.content, article.category_id, article.create_time FROM article WHERE article.create_time BETWEEN 2020-02-04 18:00:00 AND 2020-02-05 15:00:00 : 此时我们的时间就会变成“Asia/Shanghai”时区的时间。

总结:在提取数据的时候要使用django.utils.timezone.make_aware 先将datetime.datetime 从naive时间转变为aware时间,make_aware会将给定的时间转换为TIME_ZONE中指定的失去的时间。
67.ORM查询条件:range的使用,使用make_aware将navie time 转换为aware time的更多相关文章
- ORM查询条件
模板: from django.db import models class Article(models.Model): title = models.CharField(max_length=20 ...
- 68.ORM查询条件:date,time,year,week_day等
1. date: 首先查看数据库中article表的信息,由表中的create_time字段可以看出时间为2020.2.5 打印出查询的结果: <QuerySet []>:但是查询的结果为 ...
- 69.ORM查询条件:isnull和regex的使用
首先查看数据库中的article表的数据: 定义模型的文件models.py中的示例代码如下: from django.db import models class Category(models.M ...
- 64.Python中ORM查询条件:in和关联模型
定义模型的models.py文件中示例代码如下: from django.db import models class Category(models.Model): name = models.Ch ...
- 65.ORM查询条件:gte,gt,lte和lt的使用
1. gte: 代表的是大于等于,英文全称为:great than equal.举例:找到文章id大于等于3等文章,示例代码如下: 定义模型的示例代码如下: from django.db import ...
- Django(17)orm查询操作
前言 查找是数据库操作中一个非常重要的技术.查询一般就是使用filter.exclude以及get三个方法来实现.我们可以在调用这些方法的时候传递不同的参数来实现查询需求.在ORM层面,这些查询条件都 ...
- django orm 的查询条件
Django的ORM查询操作: 查询数据库操作是一个非常重要的技术.在Django中,查询一般就是使用filter.exclude.get三个方法来实现,在调用这些方法的时候传递不同的查询条件来实现复 ...
- django ORM常用查询条件
假设有一个模型 class Article(models.Model): title=models.CharField(max_length=50) content=models.TextField( ...
- ORM查询简化
文章出处 https://www.cnblogs.com/wupeiqi/articles/6216618.html 字段 常用字段 AutoField(Field) - int自增列,必须填入参数 ...
随机推荐
- 简单模拟IOC容器:为添加了@Autowired的属性赋值(初始值)
创建@Autowired注解 package com.zzj.test; import java.lang.annotation.ElementType; import java.lang.annot ...
- POJ 2386 Lake Counting 八方向棋盘搜索
Lake Counting Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 53301 Accepted: 26062 D ...
- OpenResty 实现项目的灰度发布
1.安装 openresty 依赖模块: [root@Centos opt]# yum -y install pcre-devel openssl openssl-devel postgresql-d ...
- 2019 OI日记
// 我觉得记日记是个好习惯吧 毕竟指不定哪天就学不下去了 就AFO了 就没有梦了 // [置顶]活跃于你谷普及训练场.ybt(没底气说全部).loj(提高基础部分) //优先级从前往后 因为 ...
- 使用 HTML5 视频事件
转自:http://msdn.microsoft.com/zh-cn/library/hh924822(v=vs.85).aspx 为什么要使用事件? HTML5 视频对象提供了很多事件,这些事件可以 ...
- 留学生Essay写作清晰简洁8大原则
英语Essay写作中国留学生需要掌握的一个技能,一篇文笔简洁优雅的Essay对于提高分数会有很大帮助.但目前的情况是,很多人并没有受过专门的学术Essay写作训练,在写Essay时经常会出现各种各样的 ...
- 《ES6标准入门》(阮一峰)--7.数值的扩展
1.二进制和八进制表示法 ES6 提供了二进制和八进制数值的新的写法,分别用前缀0b(或0B)和0o(或0O)表示. 0b111110111 === 503 // true 0o767 === 503 ...
- P 1038 统计同成绩学生
转跳点:
- --转载 详细介绍java中的数据结构
http://developer.51cto.com/art/201107/273003.htm 也许你已经熟练使用了java.util包里面的各种数据结构,但是我还是要说一说java版数据结构与算法 ...
- 官网英文版学习——RabbitMQ学习笔记(六)Routing
有选择的接收消息. 上一节我们使用的是fanout exchange来实现消息的发布/订阅模式,这并没有给我们带来多大的灵活性——它只能够让人盲目地进行广播.而本节我们采用direct类型的交换器来实 ...