因为数据库中存储的是UTC时区,默认状况下数据导出和group by都存在时区问题。
完全解决办法:
将以UTC时区存储的数据改成按目标时区存储,并去掉JS中的时区转换。 一、修改Odoo系统环境时区: odoo/openerp/__init__.py 文件 import os os.environ['TZ'] = 'UTC' # 将这里的UTC 改成Asia/Shanghai 或其它目标时区 二、修改 web页面时区转换的JS文件: odoo/addons/web/static/src/js/openerpframework.js 中的两个方法 openerp.str_to_datetime 字符串转时间 openerp.datetime_to_str 时间转字符串 去掉这两个方法中的UTC字符。 三、修改以UTC时间执行的SQL 查询或插入语句: 去掉全部带 "at time zone 'UTC'" 或 "at time zone 'utc'"字符串的语句。 odoo/openerp/models.py 特别是create_date、write_date字段值; odoo/openerp/addons/base/ir/ir_cron.py 定时任务中UTC时区改成当前时区; odoo/openerp/netsvc.py 备份下来的数据库名称时间标志 四、修改其余功能性模块中带 "at time zone" 字符串来取UTC时间的语句。 如 calendar 模块和 hr_timesheet_sheet模块