社区首页 >问答首页 >为什么Django要创建带有时区的Postgres时间戳列?

为什么Django要创建带有时区的Postgres时间戳列?
EN

Stack Overflow用户
提问于 2011-11-11 16:27:43
回答 3查看 10.6K关注 0票数 5

我认为Django创建了与时区无关的datetime列,但是当我查看Postgres表时,我发现那里记录的值包含时区信息。

更进一步,我发现Postgres后端指示Django创建使用时区的列。

从django/db/后端/postgresql/creation.py:

代码语言:javascript
代码运行次数:0
复制
data_types = {
        ...
        'DateTimeField':     'timestamp with time zone',
        ...

架构显示所创建的列被指定为“带时区的时间戳”。

代码语言:javascript
代码运行次数:0
复制
CREATE TABLE notification_notice
(
  ...
  created timestamp with time zone NOT NULL,
  ...

Postgres日志显示发送的update语句。Django构造了一个SQL语句,该语句使用UTC作为时区,由我的Django设置文件指导。

代码语言:javascript
代码运行次数:0
复制
UPDATE "notification_notice" SET "sender_id" = 1, "group_id" = NULL, "notice_type_id" = 1, "content_type_id" = 21, "object_id" = 3, "created" = E'2011-11-11 22:31:08.022148' WHERE "notification_notice"."id" = 14

这是我桌子的样子。创建的列的时区为"-08“。为了找到时区,Postgres必须检查系统时钟的时区。

代码语言:javascript
代码运行次数:0
复制
my_db=# select * from notification_notice limit 1;
 id | sender_id | group_id | notice_type_id | content_type_id | object_id |           created            | last_interaction_time 
----+-----------+----------+----------------+-----------------+-----------+------------------------------+-----------------------
  1 |           |        3 |             21 |              53 |         6 | 2011-11-11 14:31:02.98882-08 | 
(1 row)

问题:

Django没有对时区的政策吗?

为什么Postgres后端使用用于models.DateTimeField的时区?这是Postgres需要的吗?

有没有办法强迫Django在Postgres中创建不使用时区的时间戳列?

EN

回答 3

Stack Overflow用户

发布于 2011-11-11 17:59:28

坏消息是,问题的根源在于Python的datetime实现。

好消息是Django在这个问题上有公开的票

坏消息是这张票是在2006年开的。

好消息是,最近的提案更有用,而且似乎正在开发中。包含提案的内容很长,但内容非常丰富。

坏消息是,这一提议归结为“这是一个真正的混乱”。(尽管如此,它仍在开发中。)

更进一步,我发现Postgres后端指示Django创建使用时区的列。

不,这是Django的设计决定。PostgreSQL只存储UTC;它不存储时区,也不存储偏移量。时区在概念上就像一个环境变量,在插入或选择用于检索的时间戳时应用于时间戳。

来自django开发人员的邮件存档。。。

在数据库中没有实际的时区支持的情况下,django采取的任何操作都会给人带来不便,并且很可能与非django使用同一数据库不兼容。

这是一个大问题--一个可能使数据库与其他语言或框架不兼容的修复方法。在我工作的地方,这是一个绝对的停止;许多编程语言和框架访问数据库。

该线程中引用了SQLite、Microsoft和MySQL (日期时间数据类型,而不是时间戳),因为数据库中缺乏时区支持。

票数 16
EN

Stack Overflow用户

发布于 2017-11-05 00:13:56

我认为你的假设是错误的。存储时区信息

对于timestamp with time zone内部存储的值总是以UTC (通用协调时间,传统上称为格林尼治标准时间(格林尼治标准时间))。指定了显式时区的输入值将使用该时区的适当偏移量转换为UTC。如果输入字符串中没有指定时区,则假定它位于由系统的TimeZone参数指示的时区,并使用时区的偏移量将其转换为UTC。

因此,实际上,时区信息丢失了。但是时间的瞬间被保存下来了,

这意味着当您获得时间戳信息时,无论您或您的服务器当前处于哪个时区,都将始终正确。对于大多数应用程序来说,这正是您想要的。

票数 4
EN

Stack Overflow用户

发布于 2013-03-15 06:06:12

Postgresql能够用时区存储时间戳这一事实是一件好事。时间戳应该表示一个时间点。如果你读了"2013-03-15 14:38:00",知道具体代表了什么时间点就足够了吗?不是的!纽约可能是14:38,柏林可能是14:38,这是两个不同的时间点。因此,如果不包含特定的时区(例如UTC),就不应该有没有时区的时间戳(它们被称为“朴素”日期时间)。

在我看来,Django创建带有时区的时间戳是一件好事。您可以通过编写自己的DatetimeField覆盖该默认行为,但我不推荐它,除非您有很好的理由消除数据库中的时区(例如,因为它破坏了其他一些遗留程序)。

如果使用Django < 1.4,则postgresql客户端代码假定所有日期时间都在系统的时区。因此,如果django服务器的时区是柏林,那么在柏林时区,"2013-03-15 14:38:00“将被解释为14:38,所有这些信息都将存储在数据库中。如果删除时区信息,则在DST时间更改时会出现问题。例如,"2013-10-26 02:30:00“含糊不清:它是第一次还是第二次发生在凌晨2:30?如果您使用该路由,则必须在Django代码中将所有日期时间转换为或从UTC转换,并将UTC日期时间存储在数据库中。

如果您使用Django >= 1.4,那么默认情况下它是时区感知的,并且期望每个日期时间都有一个时区。由于python在默认情况下没有时区,所以您应该使用pytz封装来确保您操作的每个日期时间都是时区感知的。

Django关于时区的文档是一个非常好的读物。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/8101506

复制
相关文章
MySQL 子查询 嵌套查询
意思就是内层的select查到了(至少查到了一行)才进行查询,没有查到就不进行查询。
宁在春
2022/10/31
12.1K0
mysql中多表嵌套查询例子_mysql子查询嵌套规则
MySQl从4.11版后已经完全支持嵌套查询了,那么下面举些简单的嵌套查询的例子吧(源程序来自MySQL User Manual):
全栈程序员站长
2022/11/01
3.4K0
MySQL 嵌套查询_嵌套查询和嵌套结果的区别
where course.cno=sc.cno and course.cname=’数据库’ and grade>=80)[/code](3)查询计算机系最高成绩。
全栈程序员站长
2022/09/22
4.3K0
MySQL——优化嵌套查询和分页查询
嵌套查询(子查询)可以使用SELECT语句来创建一个单列的查询结果,然后把这个结果作为过滤条件用在另一个查询中。嵌套查询写起来简单,也容易理解。但是,有时候可以被更有效率的连接(JOIN)替代。
撸码那些事
2018/10/08
2.9K0
MySQL——优化嵌套查询和分页查询
mysql嵌套子查询的应用
sql语句中一个查询有时未必能满足需求,应对多表联查时就需要进行嵌套查询。嵌套查询的意思是,一个查询语句块可以嵌套在另外一个查询块的where子句中,称为嵌套查询。其中外层查询也称为父查询,主查询。内层查询也称子查询,从查询。 嵌套查询的工作方式是:先处理内查询,由内向外处理,外层查询利用内层查询的结果嵌套查询不仅仅可以用于父查询select语句使用。还可以用于insert、update、delete语句或其他子查询中。
OECOM
2020/07/01
4.2K0
嵌套查询效率_sql嵌套查询例子
嵌套查询是 SQL 中表达能力很强的一种机制,既给应用带来了方便也给查询优化带来了很大的挑战。本文总结一下经典的单机系统对嵌套查询的优化。
全栈程序员站长
2022/09/27
2.4K0
sql server嵌套查询实验_exists嵌套查询
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/169426.html原文链接:https://javaforall.cn
全栈程序员站长
2022/09/22
1.8K0
sql的嵌套查询_嵌套查询和嵌套结果的区别
SQL连接查询和嵌套查询详解 连接查询 若一个查询同时涉及两个或两个以上的表,则称之为连接查询。连接查询是数据库中最最要的查询,
全栈程序员站长
2022/09/22
3.9K0
sql的嵌套查询_嵌套查询和嵌套结果的区别
mysql DATE_SUB() 函数
SELECT OrderId,DATE_SUB(OrderDate,INTERVAL 5 DAY) AS SubtractDate FROM Orders
DencyCheng
2019/03/05
1.8K0
sql的嵌套查询_sql子查询嵌套优化
最近在做各类小应用,用到了MYSQL,有时候会用到一些比较复杂的嵌套查询,在研究怎么通过SQL实现这些。 假设下面这张表(stu)描述学生的基本信息:
全栈程序员站长
2022/09/22
5.2K0
sql嵌套查询和连接查询_sql子查询嵌套规则
WHERE department_id=( SELECT department_id
全栈程序员站长
2022/11/07
4K0
sql数据库嵌套查询_select嵌套查询
where 学号 = (select 学号 from 学生 where 姓名=”xx”);
全栈程序员站长
2022/09/22
3.8K0
sql嵌套查询例子_sql的多表数据嵌套查询
查询学生上课人数超过 “Eastern Heretic” 的任意一门课的学生人数的课程信息,请使用 ANY 操作符实现多行子查询。(Lintcode刷题记录)
全栈程序员站长
2022/09/22
3.1K0
SQL嵌套查询_sql嵌套查询返回多个字段
说到嵌套查询,首先得理解嵌套查询是什么意思,简单来说就是,一个查询语句可以嵌套在另外一个查询语句的where子句中。外层的查询称为父查询(主查询),内层的查询称为子查询(从查询)。
全栈程序员站长
2022/09/22
2.9K0
SQL嵌套查询_sql差集嵌套
派生表就是一个由查询结果生成的临时表。他是在外部查询的 FROM 中定义的。派生表的存在范围只是在外部查询中,只要外部查询结束了,派生表也就不存在了。派生表一定要写在 FROM 后面范围内,用()括起来。后面跟着派生表的名称。
全栈程序员站长
2022/09/22
2.2K0
SQL嵌套查询_sql差集嵌套
sql嵌套查询效率_sql嵌套查询返回多个字段
为了查询一个字段,使用了五层嵌套循环,但是花费了约1分钟 但是5个表的数据每个最多只有10条,怎么会这么慢呢?
全栈程序员站长
2022/09/22
2.8K0
sql嵌套查询效率_sql嵌套查询返回多个字段
Gorm-嵌套查询
嵌套查询是一种在一个查询语句中嵌套另一个查询语句的方式。在Gorm中,可以使用Preload方法来实现嵌套查询。
堕落飞鸟
2023/04/24
8950
sql中的嵌套查询_sql的多表数据嵌套查询
测试的时候发现取出的是一条数据, 因为测试的时候是一天中的两条数据, 没有不同的日期,所以当日以为是正确的 ,然而第二天写入数据了,要取出数据,却发现没有数据, 返回空的行, 以为都是代码又有问题 了,找了半天都没有 ,仔细看看了存储过程中的代码,发现这样返回的数据的确是空的。
全栈程序员站长
2022/09/22
7.1K0
实验3.4 嵌套查询
掌握SELECT语句的嵌套使用,实现多表的复杂查询,进一步理解SELECT语句的高级使用方法。
week
2018/08/27
8770
SELECT 语句中的 子查询(Sub Query)
子查询(Sub Query)或者说内查询(Inner Query),也可以称作嵌套查询(Nested Query),是一种嵌套在其他 SQL 查询的 WHERE 子句中的查询。
一个会写诗的程序员
2018/08/17
3.2K0

相似问题

MySQL SELECT IN with sub查询

21

Mysql使用update和sub查询

11

MYSQL insert after sub查询with count

30

DATE_SUB命名查询MYSQL

10

MYSQL查询Slow - Sub查询和临时表

21
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档