首页 > 数据库 >MySQL 字符串日期格式转换

MySQL 字符串日期格式转换

时间:2024-07-06 09:01:56浏览次数:25  
标签:date DATE 日期 MySQL 字符串 格式

在MySQL中,经常需要将字符串类型的日期转换成日期或时间类型,或者在不同的日期格式之间进行转换。MySQL提供了几种方法来实现这一点,包括使用STR_TO_DATE()DATE_FORMAT()函数。

1. 使用STR_TO_DATE()函数

STR_TO_DATE()函数可以将字符串转换成日期或时间格式。它接受两个主要参数:要转换的字符串和格式字符串。

语法:

STR_TO_DATE(str, format)
  • str 是要转换的字符串。
  • format 是该字符串的日期或时间格式。

示例:
假设你有一个日期字符串 '2023-04-01',并且它是以 'YYYY-MM-DD' 格式存储的,但你希望将它转换成日期类型以进行日期计算。

SELECT STR_TO_DATE('2023-04-01', '%Y-%m-%d') AS converted_date;


这将返回日期类型的结果,格式为 '2023-04-01'

2. 使用DATE_FORMAT()函数

DATE_FORMAT()函数用于将日期或时间值格式化为指定的格式。虽然这主要用于格式化日期时间值,但你也可以用它来“转换”日期到字符串的特定格式。

语法:


	DATE_FORMAT(date, format)
  • date 是日期或时间值。
  • format 是你希望返回的日期时间格式。

示例:
如果你有一个日期类型的值,并且希望将其格式化为 'YYYYMMDD' 格式的字符串。

SELECT DATE_FORMAT(NOW(), '%Y%m%d') AS formatted_date;

这里NOW()函数返回当前的日期和时间,然后DATE_FORMAT()将其格式化为 'YYYYMMDD' 格式的字符串。

3. 转换和格式化的结合使用

有时,你可能需要先将字符串转换成日期类型,然后再将其格式化为另一种格式的字符串。这可以通过结合使用STR_TO_DATE()DATE_FORMAT()来实现。

示例:
假设你有一个日期字符串 '01-Apr-2023',并且你希望将其转换为 'YYYYMMDD' 格式的字符串。

SELECT DATE_FORMAT(STR_TO_DATE('01-Apr-2023', '%d-%b-%Y'), '%Y%m%d') AS formatted_string;

这里,STR_TO_DATE()首先将字符串转换为日期类型,然后使用DATE_FORMAT()将其格式化为 'YYYYMMDD'

总结

通过STR_TO_DATE()DATE_FORMAT()函数,MySQL允许你在字符串和日期类型之间转换,并在不同的日期格式之间自由转换。这在进行数据清洗、处理和报表生成时非常有用。

起因

需要将Oracle中的数据导到MySQL中

#阻碍

在Oracle导出数据时,发现导出的SQL脚本中的日期转换是to_date('28-11-2023 14:15:17', 'dd-mm-yyyy hh24:mi:ss')的形式,但MySQL并不认识这个格式转换函数,此时需要将Oracle中这个日期转换函数替换成MySQL中的日期格式转换函数才能在MySQL中执行导出的脚本,那么在MySQL中日期如何转换呢?

#分析

to_date('28-11-2023 14:15:17', 'dd-mm-yyyy hh24:mi:ss')中,是要将给定的字符串28-11-2023 14:15:17按照dd-mm-yyyy hh24:mi:ss的格式转换成日期,那么我们也需要在MySQL找到一个函数能够将指定的字符串按照一定的格式转换成日期。

#解决

在MySQL中可以使用str_to_date(str,format)这个函数来实现将字符串按照时间格式转换成日期。那么对于Oracle中的to_date('28-11-2023 14:15:17', 'dd-mm-yyyy hh24:mi:ss')可以修改成str_to_date('28-11-2023 14:15:17', '%d-%m-%Y %H:%i:%s'),替换后就可以在MySQL执行进行日期转换了。

验证,结果如下:

#总结

  1. Oracle中字符串转日期:to_date('28-11-2023 14:15:17', 'dd-mm-yyyy hh24:mi:ss')
  2. MySQL中字符串转日期:str_to_date('28-11-2023 14:15:17', '%d-%m-%Y %H:%i:%s')
  3. MySQL常见时间格式化:(与字符串中的对应使用)
    1. %Y: 年份,四位数字
    2. %m:月份,两位数字
    3. %d: 日期,两位数字
    4. %H:小时(24小时制),两位数字
    5. %i: 分钟,两位数字
    6. %s: 秒,两位数字
  4. 扩展:MySQL中如果想将日期转换成字符串可以使用date_format(date,format)

标签:date,DATE,日期,MySQL,字符串,格式
From: https://blog.csdn.net/m0_56653160/article/details/140223502

相关文章

  • 八股文 | MySQL 一棵B+树可以存多少数据?
    ......
  • [python]Markdown图片引用格式批处理桌面应用程序
    需求使用python编写一个exe,实现批量修改图片引用,将修改后的文件生成为文件名_blog.md。有一个编辑框,允许接收拖动过来md文件,拖入文件时获取文件路径,有一个编辑框编辑修改后的文件的输出路径,用户拖入文件时,就能自动得到输出的路径作用是将md文件中的例如![image-20240706062921......
  • MySQL主从复制详解
    MySQL主从复制详解MySQL主从复制是数据库环境中常用的一种数据同步技术,用于实现数据的高可用性和负载均衡。通过主从复制,可以将一个MySQL数据库服务器的数据实时地复制到一个或多个从库中。本文将介绍MySQL主从复制的原理、配置步骤和常见问题。一、MySQL主从复制的原理M......
  • Springboot+Shiro+Mybatis+mysql实现权限安全认证
    Shiro是Apache的一个强大且易用的Java安全框架,执行身份验证、授权、密码学和会话管理。Shiro主要分为两个部分就是认证和授权两部分一、介绍Subject代表了当前用户的安全操作SecurityManager:它是Shiro框架的核心,典型的Facade模式,Shiro通过SecurityManager来管理内部组......
  • Mysql中常用函数的使用示例
    场景基础知识回顾:mysql中常用函数的使用示例。注:博客:https://blog.csdn.net/badao_liumang_qizhi实现数学函数--ABS(x)返回x的绝对值SELECTABS(-1),ABS(2);--PI()返回圆周率SELECTPI();--SQRT(x)返回非负数x的二次方根SELECTSQRT(4);--MOD(x,y)返回x被y除之后的余......
  • 语法基础——字符、字符串与字符数组
    字符、字符串和字符数组2024-07-0520:52:00星期五字符串和字符数组的区别和联系字符串和字符数组在C语言中是紧密相关的概念,但它们之间存在一些区别和联系。定义与表示:字符串在C语言中并没有专门的类型,而是通过字符数组来表示。字符数组可以用来存储一个字符串,其中字......
  • 本地Windows10怎样配置免安装版本MySQL?
    下载MySQL免安装压缩包下载地址:https://downloads.mysql.com/archives/community/解压安装1、接下来我们解压文件夹,这时我们解压的文件夹是没有my.ini文件和data目录,这时我们需要自己创建my.ini文件,data文件后期回自动生成2、新建配置my.ini文件,并添加配置信息,如下:[mysqld]#......
  • C#字符串及其常用方法
    1.string.Formatstring.Format()方法允许我们创建格式化的字符串,其中包含一个或多个占位符,可以用实际值来替换这些占位符。//基础语法string.Format("格式字符串",参数1,参数2,...)//应用stringstr="帅哥";Console.WriteLine(string.Format("我是{0}",str......
  • 【C语言习题】32.字符串旋转结果
    文章目录作业标题作业内容2.解题思路3.具体代码作业标题字符串旋转结果作业内容写一个函数,判断一个字符串是否为另外一个字符串旋转之后的字符串。例如:给定s1=AABCD和s2=BCDAA,返回1给定s1=abcd和s2=ACBD,返回0.AABCD左旋一个字符得到ABCDAAABCD左旋两个字......
  • 哈希处理字符串(模板)
    841.字符串哈希-AcWing题库#include<bits/stdc++.h>usingnamespacestd;#defineintlonglong#defineendl'\n'constintN=1e5+10;intp=131;//13331intP[N],h[N];//P存的是p的k次方,h存字符串前k个数(换化成ascll码)intfind(intl,intr){returnh[r......