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自增列,必须填入参数 ...
随机推荐
- Codeforces Round #568 (Div. 2) 选做
A.B 略,相信大家都会做 ^_^ C. Exam in BerSU 题意 给你一个长度为 \(n\) 的序列 \(a_i\) .对于每个 \(i\in [1,N]\) 求 \([1,i-1]\) 中 ...
- List循环添加数据覆盖问题
问题:java开发时,当我们使用List.add();循环添加数据,有时会出现前面添加的数据会被后面覆盖的现象.这是怎么回事尼? 会覆盖数据的代码 package com.boot.test; imp ...
- pgsql 查询jsonb中包含某个键值对的表记录
pgsql 查询jsonb中包含某个键值对的表记录 表名 table_name ,字段 combos 类型为 jsonb 可为空,示例内容如下, $arr_combos = [ ['id' => ...
- CSS-font
font:[ [ <' font-style '> || <' font-variant '> || <' font-weight '> ]? <' font ...
- 二 SVN代码冲突的解决
问题: A和B都是最新的代码,A修改了代码提交了,B也修改了代码,但是B提交的时候出现冲突的问题. 解决方案:编辑冲突 解决冲突: 方法一:将文件里面冲突的描述去掉,重新提交 方法二:软件解决冲突
- arm linux 移植 PHP
背景: PHP 是世界上最好的语言. host平台 :Ubuntu 16.04 arm平台 : 3531d arm-gcc :4.9.4 php :7.1.30 zlib :1.2.11 libxml ...
- 学习进度-10 python爬虫
学习爬虫的第一个案例是小说爬虫. 小说爬虫首先是解析小说页面源代码,在页面源代码中可以看到小说每章节的内容链接 爬虫的代码: import requests import re url = 'http ...
- dubbo 相关面试题 有用(转)
调用关系说明: · 0. 服务容器负责启动,加载,运行服务提供者. · 1. 服务提供者在启动时,向注册中心注册自己提供的服务. · 2. 服务消费者在启动时,向注册中心订阅自己所需的服务. · 3. ...
- 009.Delphi插件之QPlugins,服务的热插拔
这个DEMO用来演示服务的替换,用起来总是怪怪的感觉,效果图如下 代码如下 unit Frm_Main; interface uses Winapi.Windows, Winapi.Messages, ...
- 数据结构——java Queue类
定义 队列是一种特殊的线性表,它只允许在表的前端进行删除操作,而在表的后端进行插入操作. LinkedList类实现了Queue接口,因此我们可以把LinkedList当成Queue来用 图例 Que ...