浅谈mysql导出表数据到excel关于datetime的格式问题

 更新时间:2020年07月14日 10:38:46   作者:Listening_倾听  
这篇文章主要介绍了浅谈mysql导出表数据到excel关于datetime的格式问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

最近用mysql导出表数据到excel文件,mysql中的datetime类型导出到excel(excel2016)中被excel识别成它自己默认的日期格式了,在mysql中的格式形如 yyyy-mm-dd hh:mm:ss,到了excel变成了 yyyy/m/d h:mm,看起来不太习惯,当然可以通过设置excel单元格格式改成自定义格式 yyyy-mm-dd hh:mm:ss,但是这样多了一个步骤,能不能直接从mysql导出到excel的就是mysql显示的样式呢?当然可以。

开始猜想是由于mysql中该字段是datetime类型的,导出到excel后excel自动转为它的日期类型,所以可以通过mysql的date_format函数把datetime转为字符串,以为没有问题,结果还是一样的,猜想是对于这种标准日期的字符串的格式excel也会识别成日期格式,于是在导出语句中加上一个字符串的日期,验证了我的猜想。所以就寻思打破这种默认的日期格式但使得它看上去又没什么差别,所以在用date_format转为字符串时,在前面加上一个空格,这样就完美解决了。

测试用表及测试数据

CREATE TABLE `users` (
 `username` varchar(255) NOT NULL,
 `create_time` datetime NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
 
# 插入测试数据
INSERT INTO `users`(`username`, `create_time`) VALUES 
 ('李四', '2018-10-11 15:54:23'),
 ('张三', '2018-10-12 15:54:14');

导出excel语句,注意DATE_FORMAT函数里面的格式前面加了个空格(由于表的格式是utf8的,要保证excel打开后不乱码,需要把格式转换为gbk)

SELECT
 username,
 DATE_FORMAT( create_time, ' %Y-%m-%d %H:%i:%s' ) 
FROM users 
 INTO OUTFILE '/tmp/user_info.xls' 
 CHARACTER SET gbk;

大功告成,这样导出的excel,不会在把日期识别成日期格式,而变成了文本格式,这样就能展示自己想要的风格的日期了

补充知识:将Excel文件导入到Navicat Premium中日期变为0000-00-00的解决方案

问题

在某些场景下,需要将本地文件导入到Navicat中。笔者今天遇到的问题是,将excel文件成功导入后,一个在excel中原本正确的日期字段在Navicate中却变成了“0000-00-00 00:00:00”,实在是匪夷所思。

分析

经过观察发现,该日期字段在excel中似乎没有全部显示,比如本来是2018/10/1 0:01:42,excel中显示为01:42.0,于是尝试在excel中修改了该列的单元格格式,重新导入Navicate中,问题得到解决。详细解决方法请见下方。

解决方法

1.导入前,在excel中修改单元格格式,设置为自定义,类型为yyyy/m/d h:mm:ss,并保存文件。

2.重新将文件导入到Navicate中即可。

以上这篇浅谈mysql导出表数据到excel关于datetime的格式问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • mysql left join的基本用法以及on与where的区别

    mysql left join的基本用法以及on与where的区别

    我们在写sql语句的时候,总是无法避免使用到连接关键词,比如内连接、外连接,下面就是详细的介绍,需要的朋友可以参考下
    2023-05-05
  • Mysql聚合函数的使用介绍

    Mysql聚合函数的使用介绍

    今天的章节我们将要来学习一下 “聚合函数” ;首先我们需要学习聚合函数对数据进行统计分析,比如说求最大值、最小值、平均值之类的场景。但是单纯的使用聚合函数,只能做全表范围的统计分析
    2022-10-10
  • Innodb存储引擎中的后台线程详解

    Innodb存储引擎中的后台线程详解

    后台线程的主要作用是负责刷新内存池中的数据,保证缓存中的内存缓存的是最近的数据,下面这篇文章主要给大家介绍了关于Innodb存储引擎中后台线程的相关资料,需要的朋友可以参考下
    2022-04-04
  • mysql alter table修改表命令整理

    mysql alter table修改表命令整理

    这篇文章主要介绍了mysql alter table修改表命令整理的相关资料,需要的朋友可以参考下
    2016-10-10
  • 浅谈mysql8.0新特性的坑和解决办法(小结)

    浅谈mysql8.0新特性的坑和解决办法(小结)

    这篇文章主要介绍了浅谈mysql8.0新特性的坑和解决办法(小结),小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-09-09
  • mysql中用于数据迁移存储过程分享

    mysql中用于数据迁移存储过程分享

    mysql 数据迁移用的一个存储过程,需要的朋友可以收藏下。
    2011-05-05
  • Window中MySQL绕过密码登录的底层原理详解

    Window中MySQL绕过密码登录的底层原理详解

    在 MySQL 中,root 用户的密码存储和认证机制随着版本的升级发生了变化,绕过密码登录主要依赖于 --skip-grant-tables 选项,本文将详细分析 MySQL 绕过密码的底层原理,并解释为什么某些操作在 --skip-grant-tables 模式下无效,以及如何正确生效修改
    2025-02-02
  • MySQL SQL 语法参考

    MySQL SQL 语法参考

    MySQL SQL 语法参考...
    2006-12-12
  • MySQL分库分表动态扩容缩容方式

    MySQL分库分表动态扩容缩容方式

    MySQL分库分表动态扩容缩容方案,通过选择数据库中间件,设计分库分表方案,进行环境测试,完成单库单表到分库分表的迁移,实现双写方案,并上线提供服务,扩容时,通过增加数据库服务器,呈倍数扩容,由DBA负责库表迁移,无需修改路由规则,即可基于新的资源提供服务
    2025-02-02
  • CentOS 7 安装Percona Server+Mysql

    CentOS 7 安装Percona Server+Mysql

    这篇文章主要介绍了CentOS 7 安装Percona Server+Mysql的相关资料,需要的朋友可以参考下
    2018-11-11

最新评论