Heim > Datenbank > MySQL-Tutorial > Hauptteil

Welche Datums- und Uhrzeittypen und Formatierungsmethoden gibt es in MySQL?

王林
Freigeben: 2023-06-02 22:49:04
nach vorne
5051 Leute haben es durchsucht

Welche Datums- und Uhrzeittypen und Formatierungsmethoden gibt es in MySQL?

【1】Datum/Uhrzeit-Typ in MySQL

In MySQL sind Datum, Datum/Uhrzeit, Uhrzeit, Jahr und Zeitstempel häufig verwendete Zeiten. ?? #Maximum

Ein Wert von Null bedeutet Datum4# 🎜🎜 #0000-00-00 #🎜 🎜#datetime81000-01-01 00:00:009999-12-31 23:59:59 #🎜 🎜#Zeitstempel#🎜 🎜# 19700101080001Irgendwann im Jahr 20380000000000000000#🎜🎜 #3#🎜🎜 #-838:59#🎜🎜 #Jahr1190121550000#🎜 🎜## 🎜🎜##🎜 🎜#
1000-01-01 9999-12-31
0000-00-00 00:00:00
4 #🎜#Zeit
838:59:59 00:00:00

Ausführliche Erklärung

  • datetime : Zeit-Datumstyp, das Format ist JJJJ-mm-tt HH:ii:ss, der Bereich liegt zwischen 1000 und 9999. Aber es gibt einen Nullwert, 0000-00-00 00:00:00; datetime : 时间日期型,格式是YYYY-mm-dd HH:ii:ss,表示的范围是从1000到9999。但是有零值,0000-00-00 00:00:00;

  • date:日期,就是datetime中的date部分;

  • time:时间(段),指定的某个区间之间,从-时间到+时间(有负时间表示);

  • timestamp:时间戳,并不是常规意义时间戳(如:14253685),范围是’1970-01-01 00:00:00’到2037年。格式为YYYY-mm-dd HH:ii:ss,格式与datetime完全一致;

  • year:yy和yyyy,yyyy的范围是1901-2155,yy的范围是1970-2069。

两位year(00-69表示2000-2069,70-99表示1970~1999)。当应用只需要记录年份时,year比date更省空间

SQL语句实例

create table my_date(
	d1 datetime,
	d2 date,
	d3 time,
	d4 timestamp,
	d5 year
)charset utf8;
desc my_date
Nach dem Login kopieren

如下图所示:year默认为4位,即YYYY; timestamp不能为空,有默认值,在创建新记录和修改现有记录的时候都对这个数据列刷新。

Welche Datums- und Uhrzeittypen und Formatierungsmethoden gibt es in MySQL?

如下分别插入几条数据并对time做差异分析:

insert into my_date VALUES('2015-09-28 11:50:36','2015-09-28','11:50:54','2015-09-28 11:51:08','2015');
insert into my_date VALUES('2015-09-28 11:50:36','2015-09-28','-11:50:54','2015-09-28 11:51:08','2015');-- -11
insert into my_date VALUES('2015-09-28 11:50:36','2015-09-28','-211:50:54','2015-09-28 11:51:08','2015');-- -2 11
insert into my_date VALUES('2015-09-28 11:50:36','2015-09-28','-2 11:50:54','2015-09-28 11:51:08','2015');-- -2过去两天
#year用69标识-2069
insert into my_date VALUES('2015-09-28 11:50:36','2015-09-28','11:50:54','2015-09-28 11:51:08','69');-- 69
#year用70标识-1970
insert into my_date VALUES('2015-09-28 11:50:36','2015-09-28','11:50:54','2015-09-28 11:51:08','70');-- 70
Nach dem Login kopieren

Welche Datums- und Uhrzeittypen und Formatierungsmethoden gibt es in MySQL?

Welche Datums- und Uhrzeittypen und Formatierungsmethoden gibt es in MySQL?

timestamp字段

默认情况下只要当前所在的记录被更新,该字段一定会自动更新成当前时间。

update my_date set d1 = SYSDATE() where d5=69;
select * from my_date
Nach dem Login kopieren

Welche Datums- und Uhrzeittypen und Formatierungsmethoden gibt es in MySQL?

那么MySQL可以拿到真正的时间戳吗?当然可以!

select UNIX_TIMESTAMP();
Nach dem Login kopieren

Welche Datums- und Uhrzeittypen und Formatierungsmethoden gibt es in MySQL?

测试实例

4.1 查询当前时间

SELECT SYSDATE() from dual;
Nach dem Login kopieren

Welche Datums- und Uhrzeittypen und Formatierungsmethoden gibt es in MySQL?

4.2 将当前时间插入以上几种类型列中

insert INTO `user` (name,number,date,datetime,timestamp,time,year)
VALUES (
'Loum',3,SYSDATE(),SYSDATE(),SYSDATE(),SYSDATE(),2016
);
Nach dem Login kopieren

Welche Datums- und Uhrzeittypen und Formatierungsmethoden gibt es in MySQL?

4.3 mysql中datetime类型的长度位数

如下所示,通常我们MySQL中设计datetime类型长度都默认为0:

`work_time` datetime(0) DEFAULT NULL COMMENT '清收时间',
Nach dem Login kopieren

常见的时间格式通常是2020-08-29 12:52:16,其中插入当前时间。但是如果datetime(n)中的n不为0呢?

`work_time` datetime(2) DEFAULT NULL COMMENT '清收时间',
# datetime(n)中的n最大值为6
`work_time` datetime(6) DEFAULT NULL COMMENT '清收时间',
Nach dem Login kopieren

这时在MySQL中会分别显示如下:

2020-08-29 12:52:16.01
2020-08-29 12:52:16.014057

会发现最后有一个小数点且小数点后面会分别对应相应位数的数字–这称之为纳秒。

总结如下:

  • date : 只有日期,没有时间;

  • datetime:有时间,有日期;

  • time:只有时间 ,精确到分秒 ;

  • timestamp:时间戳,精确到分秒;

  • year

date: Datum ist der Datumsteil von datetime;

time</code >: Zeit (Segment), zwischen einem angegebenen Intervall, von - Zeit bis + Zeit (dargestellt durch negative Zeit); </strong></p><p></p><code>timestamp: Zeitstempel, kein herkömmlicher Zeitstempel (Beispiel: 14253685) , der Bereich ist „1970-01-01 00:00:00“ bis 2037. Das Format ist JJJJ-MM-TT HH:ii:ss,

Das Format stimmt vollständig mit datetime überein; Welche Datums- und Uhrzeittypen und Formatierungsmethoden gibt es in MySQL?

🎜🎜🎜year: yy und yyyy, der Bereich von yyyy ist 1901-2155, und der Bereich von yy ist 1970-2069. 🎜🎜🎜🎜 Zweistelliges Jahr (00-69 bedeutet 2000-2069, 70-99 bedeutet 1970~1999). Wenn die Anwendung nur das Jahr aufzeichnen muss, spart das Jahr mehr Platz als das Datum und hat einen Standardwert. Diese Datenspalte wird aktualisiert, wenn neue Datensätze erstellt und vorhandene Datensätze geändert werden. 🎜🎜Was sind die Datums- und Uhrzeittypen und Formatierungsmethoden in MySQL🎜 🎜Fügen Sie mehrere Datenelemente ein und führen Sie die Zeitdifferenzanalyse wie folgt durch: 🎜
SELECT DATE_FORMAT(SYSDATE(),&#39;%Y-%m-%d %H:%i:%s&#39;) from dual;
Nach dem Login kopieren
🎜MySQL Was sind die Datums- und Uhrzeittypen und Formatierungsmethoden in 🎜🎜MySQL Was? Ist der Datums- und Uhrzeittyp und die Formatierungsmethode?🎜

Zeitstempelfeld

🎜Solange der aktuelle Datensatz aktualisiert wird, wird dieses Feld standardmäßig automatisch auf die aktuelle Zeit aktualisiert. 🎜
str_to_date(
	&#39;2016-12-15 16:48:40&#39;,
	&#39;%Y-%m-%d %H:%i:%S&#39;
)
Nach dem Login kopieren
Nach dem Login kopieren
🎜Was sind die Datums- und Uhrzeittypen und Formatierungsmethoden in MySQL 🎜🎜Kann MySQL also den echten Zeitstempel erhalten? Sicher! 🎜rrreee🎜Was sind die Datums- und Uhrzeittypen und Formatierungsmethoden in MySQL 🎜

🎜Testbeispiel🎜

🎜🎜4.1 Aktuelle Uhrzeit abfragen🎜🎜rrreee🎜Was sind die Datums- und Uhrzeittypen und Formatierungsmethoden in MySQL🎜🎜🎜4.2 Fügen Sie die aktuelle Uhrzeit in die oben genannten Spaltentypen ein🎜🎜rrreee🎜Was sind die Datums- und Uhrzeittypen und Formatierungsmethoden in MySQL🎜🎜🎜4.3 Die Länge des Datums-/Uhrzeittyps in MySQL in Ziffern🎜 🎜🎜 ist wie folgt: Wie gezeigt, ist die Länge des datetime-Typs in unserem MySQL normalerweise standardmäßig auf 0 ausgelegt: 🎜rrreee🎜Das übliche Zeitformat ist normalerweise 2020-08-29 12:52:16, in dem die aktuelle Zeit wird eingefügt. Was aber, wenn n in datetime(n) nicht 0 ist? 🎜rrreee🎜Zu diesem Zeitpunkt wird es in MySQL wie folgt angezeigt: 🎜
🎜2020-08-29 12:52:16.01🎜2020-08-29 12:52:16.014057🎜
🎜Das werden Sie Finden Sie heraus, dass es am Ende eine gibt. Der Dezimalpunkt und die Anzahl der Nachkommastellen entsprechen der Anzahl der Ziffern – dies wird als Nanosekunde bezeichnet. 🎜🎜🎜 wird wie folgt zusammengefasst: 🎜🎜🎜🎜🎜date: Nur Datum, keine Uhrzeit; 🎜🎜🎜🎜datetime: Es gibt Zeit, aber Datum; 🎜🎜 🎜🎜Zeit: nur Zeit, auf Minuten und Sekunden genau; 🎜🎜🎜🎜Zeitstempel: Zeitstempel, auf Minuten und Sekunden genau; 🎜🎜🎜🎜Jahr< /code>: Jahr, z. B. 2002, wenn es als 15.01.2002 geschrieben wird, wird die Berechnung durchgeführt und das Einfügeergebnis ist 1986 Sie können die Funktion date_format( ) verwenden, um eine Zeitkonvertierung durchzuführen. 🎜rrreee🎜🎜🎜

date_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)
%pAM 或 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 位

str_to_date()函数

字符串转换为date:

str_to_date(
	&#39;2016-12-15 16:48:40&#39;,
	&#39;%Y-%m-%d %H:%i:%S&#39;
)
Nach dem Login kopieren
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonWelche Datums- und Uhrzeittypen und Formatierungsmethoden gibt es in MySQL?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:yisu.com
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage