实战演练 | 在 Navicat 中格式化日期和时间

Navicat 支持团队收到来自用户常问的一个问题是,如何将网格和表单视图中的日期和时间进行格式化。其实这个很简单。今天,我们将介绍在 Navicat Premium 中进行全局修改日期和时间格式的步骤。

如果你想边学边用,欢迎点击 这里 下载免费全功能试用版。

你可以在"选项"对话中的"记录"页面设置日期和时间的显示格式。通过点击主菜单中的"工具"->"选项"来访问它:

在"记录"页面的"显示格式"部分,我们可以看到日期、时间和日期时间格式(红色框标注部分):

设置格式

以 Sakila 示例数据库为例,对其日期时间格式进行更新。Sakila 数据库中大多数表都包含日期时间字段,名为 last_update,可用于审计。我们可以从截图中的 actor 表中看到(红色框标注部分)它:

默认情况下,Navicat 以数据库定义的格式来显示日期和时间。在 MySQL 中,以"YYYY-MM-DD hh:mm:ss"格式显示日期时间,如"2019-10-12 14:35:18"(注意使用24小时制)。

标准 SQL 和 ODBC 的日期和时间字符

"YYYY-MM-DD hh:mm:ss"字符串中的字母含义是标准 SQL 和 ODBC 日期和时间字符的一部分,这些是表示 SQL 查询中的日期和时间值的标准化方法。它们为在 SQL 语句中指定日期和时间值提供了一个一致且与平台独立的方法。以下是一个包含每个字母样式及其含义的列表。你需要熟悉它们,因为 Navicat 也使用它们来设置日期和时间格式:

  • c - 使用系统全局变量指定的格式显示日期,然后使用系统全局变量指定的格式显示时间。 如果日期时间值恰好为午夜,则不显示时间。

  • d - 将日显示为无前导零的数字(1-31)。

  • dd - 将日显示为有前导零的数字(01-31)。

  • ddd - 将日显示为缩写(Sun-Sat)。

  • dddd - 将日显示为完整名称(Sunday-Saturday)。

  • ddddd - 使用系统全局变量指定的格式显示日。

  • dddddd - 使用系统全局变量指定的格式显示日。

  • m - 显示没有前导零的月份数字(1-12)。如果 m 说明符紧跟在 h 或 hh 说明符后面,则显示分钟而不是月份。

  • mm - 显示有前导零的月份数字(01-12)。如果 mm 说明符紧跟在 h 或 hh 说明符后面,则显示分钟而不是月份。

  • mmm - 使用系统全局变量中提供的字符串,将月份显示为缩写形式(Jan-Dec)。

  • mmmm - 使用系统全局变量中提供的字符串,将月份显示为完整名称(January-December)。

  • yy - 将年份显示为两位数(00-99)。

  • yyyy - 将年份显示为四位数(0000-9999)。

  • h - 将小时数显示为有前导零的数字(00-23)。

  • hh - 将小时数显示为有前导零的数字(00-23)。

  • n - 将分钟数显示为无前导零的数字(0-59)。

  • nn - 将分钟数显示为有前导零的数字(00-59)。

  • s - 秒数显示为无前导零的数字(0-59)。

  • ss - 将秒数显示为有前导零的数字(0-59)。

  • t - 使用系统全局变量指定的格式显示时间。

  • tt - 使用系统全局变量指定的格式显示时间。

  • am/pm - 对于前面的 h 或 hh 说明符使用 12 小时制,则中午之前的任何小时显示 'am',中午之后的任何小时显示 'pm'。am/pm 说明符可以使用小写、大写或混合大小写,并相应地显示结果。

  • a/p - 对于前面的h或hh说明符使用 12 小时制,则中午之前的任何小时显示 'a',中午之后的任何小时显示 'p'。a/p 说明符可以使用小写、大写或混合大小写,并相应地显示结果。

  • ampm - 对于前面的 h 或 hh 说明符使用 12 小时制,中午之前的任何小时显示系统全局变量的内容,对于中午之后的任何小时显示系统全局变量的内容。

  • / - 日期分隔符。在一些地区,可能会使用其他字符来表示日期分隔符。

  • : - 时间分隔符。在一些地区,可能会使用其他字符来表示时间分隔符。

  • 'xx' 或 "xx" - 用单引号或双引号括起来的字符会按原样显示,格式不会发生更改。

现在,让我们将全局 Navicat 日期时间格式更改为不带前导零的数字日期、三个字母的月份缩写以及包括 AM 或 PM 指示符的 12 小时制时间来表示。

将上述指令作为指南,将得出格式字符串"mmm d, yyyy hh:mm:ss AM/PM"。在输入时,我们可以在"输出"字段中实时查看结果:

点击"确定"按钮并关闭选项对话框后,所有的日期时间字段都将使用我们定义的日期时间格式显示。这是我们前面提到的 actor 表的 last_update 列:

请记住,新格式将适用于所有数据库。为了确认这一点,让我们看一下 classicmodels 数据库中的 orders 表。它包含三个日期时间列,但只设置了日期部分。这些列也将按照我们的新格式显示其值:

结语

本文中,我们了解了如何在"选项"对话框中轻松地修改全局的日期和时间格式。虽然我们今天在这里使用的是 Navicat Premium ,但其他 Navicat 产品(如 Navicat for MySQL 或 Navicat for SQL Server)的操作方式亦完全相同。

往期回顾

Navicat 16 已支持 Redis

Navicat 16 已支持华为云 GaussDB

Navicat 16 已支持蚂蚁集团 OceanBase 全线数据库

Navicat 常见技术教程

Navicat 入选中国信通院发布的《中国数据库产业图谱(2023)》

相关推荐
阿华的代码王国18 分钟前
MySQL ------- 索引(B树B+树)
数据库·mysql
Hello.Reader1 小时前
StarRocks实时分析数据库的基础与应用
大数据·数据库
执键行天涯1 小时前
【经验帖】JAVA中同方法,两次调用Mybatis,一次更新,一次查询,同一事务,第一次修改对第二次的可见性如何
java·数据库·mybatis
yanglamei19621 小时前
基于GIKT深度知识追踪模型的习题推荐系统源代码+数据库+使用说明,后端采用flask,前端采用vue
前端·数据库·flask
工作中的程序员1 小时前
ES 索引或索引模板
大数据·数据库·elasticsearch
严格格1 小时前
三范式,面试重点
数据库·面试·职场和发展
微刻时光2 小时前
Redis集群知识及实战
数据库·redis·笔记·学习·程序人生·缓存
单字叶2 小时前
MySQL数据库
数据库·mysql
mqiqe2 小时前
PostgreSQL 基础操作
数据库·postgresql·oracle
just-julie2 小时前
MySQL面试题——第一篇
数据库·mysql