ホームページ  >  記事  >  データベース  >  MySQLの取得時間やフォーマット変換の各種操作方法を詳しく解説

MySQLの取得時間やフォーマット変換の各種操作方法を詳しく解説

WBOY
WBOY転載
2022-11-07 17:06:322533ブラウズ

この記事では、主にmysqlの取得時間や形式変換方法などの関連コンテンツを紹介するビデオチュートリアルに関する関連知識をまとめていますので、一緒に見ていきましょう。

MySQLの取得時間やフォーマット変換の各種操作方法を詳しく解説

推奨学習: mysql ビデオ チュートリアル

1. SQL 時間ストレージの種類

まず、時間を操作するには、まずこのデータ型で何ができるのか、また何に使用されるのかを理解する必要があります。 MySQL に日付を保存するために一般的に使用されるデータ型は、Date、Datetime、Timestamp の 3 つです。

1.date

カレンダーの日付、例: 「2022-6-17」。形式は: %Y-%m-%d。 Python、JAVA などの他の言語では、関数の出力 Date は yyyy-mm-dd の形式であり、この形式は非常に正確な業務運営に使用されます。

2.datetime

特定の日時 例: '2022-6-17 17:00:22' 形式: %Y-% m -%d %H:%M:%s。この時間形式は、ビジネス要件で秒単位の精度が必要な場合に使用できます。

3.time

特定の時間には日付は含まれません。たとえば、「17:11:00」の形式は次のとおりです: %H:% MS。この時間形式は、ビジネス要件で毎日の時間のみが必要な場合に使用できます。

4.timestamp

datetime ストレージ タイプと同様に、時刻と日付の両方も保存されます。フォーマット形式は次のとおりです: %Y-%m-%d %H:%M:%s.

    PS.datetime と timestamp の違い
  • 保存方法が異なります。TIMESTAMP の場合、クライアントが挿入した時刻を現在のタイムゾーンから UTC (世界標準時) に変換して保存します。クエリを実行すると、クライアントの現在のタイムゾーンに変換されて返されます。 DATETIME の場合、変更は行われず、入力と出力は基本的に同じです。
  • 保存される時間範囲も異なります。タイムスタンプが保存できる時間範囲は次のとおりです: '1970- 01-01 00:00:01.000000」から「2038-01-19 03:14:07.999999」まで。 datetime が保存できる時間範囲は、「1000-01-01 00:00:00.000000」から「9999-12-31 23:59:59.999999」です。
  • タイムスタンプには、自動初期化と更新のメカニズムがあります。つまり、データを挿入するときに値が割り当てられていない場合、現在の [タイムスタンプ] に対応する形式が自動的に書き込まれます。他のフィールドを更新すると、保存範囲を除く現在の時刻に自動的に更新されます。

    比較の概要
  • タイムスタンプと日付時刻。保存方法が違うだけで、大きな違いはありません。クロスタイムゾーンのビジネスには、TIMESTAMP の方が適しています。
  • タイムスタンプには、自動初期化と更新機能があります。レコードを更新すると、列の値が自動的に更新されます。これが datatime との最大の違いです

##5.varchar/bigint

ストレージ形式が固定されていない場合があり、ストレージ時間が発生する可能性があります。正確である場合もあります日、時間、または月のみ この種の柔軟で固定されていない時刻は、文字列または BIGINT 形式を使用してのみ実行できます。

# これには、抽出と後処理、計算用の時間形式への変換、または必要な時間を取得するための論理演算の実行が必要です。

2. 時刻を取得します

1.now()

ローカル特定の日付と時刻を取得します:

select now() as time

# # 2.localtime()

now():

select LOCALTIME() as time

3.current_timestamp()## と同じ、ローカル固有の日付と時刻を取得します。

#now() と同じ、ローカル固有の日付と時刻を取得します:

select current_timestamp() as time

4.localtimestamp()

ローカル固有の日付と時刻を取得します日付と時刻、現在と同じ () 同じ:

select LOCALTIMESTAMP() as time

以上这4种函数功能都与now()功能一样获取当地具体日期和时间,平常使用一个now()就好了好记。

5.sysdate()

获取当地具体日期和时间,与now()上述几个函数不一样的是,now()在执行该函数之前就已得到了。

select sysdate() as time

以上函数均为获取具体日期和时间。


 6.curdate()

获取当地具体日期:

select curdate() as time

7.current_time()

获取当地具体日期,和curdate()函数功能一样:

select current_date() as time

 以上函数均为获取具体日期。


8. curtime()

获取具体的时间:

select curtime() as time

9.current_time()

获取具体的时间:

select current_time() as

 以上均为获得具体时间的函数。


10. utc_date()

获取UTC时间的日期,因为我们是东八时区要快8个小时,本地时间=UTC时间+8小时。

select utc_date() as time

由于博主现在是晚上九点所以还是6月17日,如果是早上八点之前就是6月16号了。

11.utc_time

获取UTC时间的时间。

select utc_time() as time

12.utc_timestamp()

获取UTC时间的具体日期和时间,在做跨国业务时非常有用。

select utc_timestamp() as time

 以上为获取UTC时间函数。


 13.HOUR(SYSDATE())

获取系统具体小时:

select HOUR(SYSDATE()) as time

 14.MINUTE(SYSDATE())

获取当前系统分钟:

select MINUTE(SYSDATE()) as time

 其他获取year,month,day,second,microsecond都可以通过这种方法获得,这里不再演示。

三、转换时间

如果是用BIGINT或者是字符串varchar存储的时间数据就需要将该列数据转换为时间数据,或者输入一个字符串想要转化为时间格式都需要转换函数,这里详细介绍各种方法解决这种问题:

1.cast() 

基础语法格式:

cast( <数据> as <数据类型> )

可转换的类型有字符串varchar、日期date、时间time、日期时间datetime、浮点型decimal、整数signed、无符号整数unsigned。 

例如我们拿到展示的sql表格:

 该列类型为BIGINT:

 下面直接用cast转换为时间类型:

select cast(time as date) as timefrom value_test

 可见如果有与其他format不对应,只记录到月或者记录到小时时,将不能识别转为时间类型。也可以切换成time或是datetime:

select cast(time as datetime) as timefrom value_test

select cast(time as time) as timefrom value_test

只要是有6个字符的都会被识别为%H:%M:s。

我们可以修改表再看:

 2.convert()

基础语法格式:

convert(<数据>,<数据类型>)
select CONVERT(time ,date) as timefrom value_test

 和上述cast的功能一样,但是cast是强制转换。

所以说如果涉及到记录有多个不同维度的时间数据存储的时候,一般是不用数据库时间类型去做存储的。看cast的例子就可以看出。

3.str_to_date()

str_to_date()函数可以将时间格式的字符串按照所指定的显示格式(format)转换为不同的时间类型。

基础语法格式:

str_to_date(<字符串>,<format格式>')
select str_to_date(time,'%Y%m%d') as timefrom value_test

 这个函数自由性要比cast和convert的自由性高很多,可以自由定义format,但是不会仅显示单个年或日,后面会根据字符的长度补零填充:

select str_to_date(time,'%Y') as timefrom value_test

 这里我们可以更改表格的时间观察是否不满足或者超过标准的时间格式能够被识别:

select str_to_date(time,'%Y%m%d') as timefrom value_test

select str_to_date(time,'%Y%m%d%H%i%S') as timefrom value_test

 可见兼容能力是很强的。

如果是时间都是统一格式记录的直接使用cast或者convert快速转换为时间格式就好了,若是记录的有多个维度的时间应该使用str_to_date函数来转换。

四、时间转换

时间转换一般是把时间类似数据转换为其他类型数据,以上例子cast()函数和convert()函数都可以做到。改变一下位置就好了,由于上述已经提到这里就做两个简单的例子展示:

1.cast()

select cast(create_time as signed) as timefrom value_test

2.convert()

select convert(create_time ,signed) as timefrom value_test

 3.date_format()

其实最主要的还是使用data_format(),date_format()函数可以以不同的格式显示日期/时间数据,可以实现日期转换成字符串。也就是将时间数据读取之后按照format形式转换为字符串输出,当然转换为了字符串我们又可以转为其他的格式。

语法格式:

date_format(<时间类型数据>,<format格式>)

其中format的格式参数可选的有:

格式 描述
%a 星期名缩写
%b 月名缩写
%c 代表几月的数值
%D 带时序后缀的数值-天
%d 天数,数值(00-31)
%e 天数,数值(0-31)
%f 微秒
%H 小时 (00-23)
%h 小时 (01-12)
%I 小时 (01-12)
-- --------------------------
%i 分钟,数值(00-59)
%j 转换为天数 (001-366)
%k 小时 (0-23)
%l 小时 (1-12)
%M 月名
%m 月,数值(00-12)
%p AM 或 PM
%r 时间,12-小时(hh:mm:ss AM 或 PM)
%S 秒(00-59)
%s 秒(00-59)%T 时间, 24-小时 (hh:mm:ss)
-- -----------------------------
%U 从年初首周开始计算 (00-53)  星期日是一周的第一天
%u 从年初首周开始计算 (00-53)  星期一是一周的第一天
%V 周 (01-53) 星期日是一周的第一天,与 %X 使用
-- ----------------------------
%v 周 (01-53) 星期一是一周的第一天,与 %x 使用
%W 星期名
%w 当前周的天数,(0=星期日, 6=星期六)
%X 年,其中的星期日是周的第一天,4 位,与 %V 使用
%x 年,其中的星期一是周的第一天,4 位,与 %v 使用
-- --------------------------
%Y 年,4 位
%y 年,2 位

自己大家可自己随意组合使用:

select date_format(create_time, '%x%v') as timefrom value_test

但是记住转换输出的都为字符串,转换为其他类型都需要再次转换.

推荐学习:mysql视频教程

以上がMySQLの取得時間やフォーマット変換の各種操作方法を詳しく解説の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はjuejin.imで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。