Maison >base de données >tutoriel mysql >Quels sont les types de date et d'heure et les méthodes de formatage dans MySQL
Dans MySQL, la date, la dateheure, l'heure, l'année et l'horodatage sont des types d'heure couramment utilisés
le type de données | occupe des octets | valeur minimale | Maximum value | Une valeur de zéro signifie |
---|---|---|---|---|
date | 4 | 1000-01-01 | 9999-12-31 | 0000-00-00 |
datetime | 8 | 1000 -01-01 00:00:00 | 9999-12-31 23:59:59 | 0000-00-00 00:00: 00 |
horodatage | 4 | 19700101080001 | Quelqu'un en 2038 | 0000000000000000 |
temps | 3 | -838:59:59 | 838:59:59 | 00:00:00 |
année | 1 | 1901 | 2155 | 0000 |
Explication détaillée
datetime
: Type heure date, le format est AAAA -mm-jj HH:ii:ss, la plage va de 1000 à 9999. Mais il y a une valeur nulle, 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更省空间
create table my_date( d1 datetime, d2 date, d3 time, d4 timestamp, d5 year )charset utf8; desc my_date
如下图所示:year默认为4位,即YYYY; timestamp不能为空,有默认值,在创建新记录和修改现有记录的时候都对这个数据列刷新。
如下分别插入几条数据并对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
默认情况下只要当前所在的记录被更新,该字段一定会自动更新成当前时间。
update my_date set d1 = SYSDATE() where d5=69; select * from my_date
那么MySQL可以拿到真正的时间戳吗?当然可以!
select UNIX_TIMESTAMP();
4.1 查询当前时间
SELECT SYSDATE() from dual;
4.2 将当前时间插入以上几种类型列中
insert INTO `user` (name,number,date,datetime,timestamp,time,year) VALUES ( 'Loum',3,SYSDATE(),SYSDATE(),SYSDATE(),SYSDATE(),2016 );
4.3 mysql中datetime类型的长度位数
如下所示,通常我们MySQL中设计datetime类型长度都默认为0:
`work_time` datetime(0) DEFAULT NULL COMMENT '清收时间',
常见的时间格式通常是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 '清收时间',
这时在MySQL中会分别显示如下:
2020-08-29 12:52:16.01
2020-08-29 12:52:16.014057
会发现最后有一个小数点且小数点后面会分别对应相应位数的数字–这称之为纳秒。
总结如下:
date
: 只有日期,没有时间;
datetime
:有时间,有日期;
time
:只有时间 ,精确到分秒 ;
timestamp
:时间戳,精确到分秒;
year
date
: La date est la partie date de datetime.
time
: temps (segment), entre un intervalle spécifié, de - heure à + heure (représenté par un temps négatif) # ; 🎜🎜#
timestamp
: horodatage, pas un horodatage conventionnel (tel que : 14253685), la plage est '1970-01-01 00 :00 : 00' à 2037. Le format est AAAA-mm-jj HH:ii:ss,
année ;
: aa et aaaa, la plage de aaaa est de 1901 à 2155 et la plage de aa est de 1970 à 2069. #🎜🎜##🎜🎜##🎜🎜##🎜🎜# Année à deux chiffres (00-69 signifie 2000-2069, 70-99 signifie 1970~1999). Lorsque l'application a uniquement besoin d'enregistrer l'année, l'année est plus peu encombrante que la date. Vide, avec la valeur par défaut, cette colonne de données sera actualisée lors de la création de nouveaux enregistrements et de la modification des enregistrements existants. #🎜🎜##🎜🎜##🎜🎜##🎜🎜# Insérez plusieurs données et effectuez une analyse des différences à temps comme suit : #🎜🎜#SELECT DATE_FORMAT(SYSDATE(),'%Y-%m-%d %H:%i:%s') from dual;#🎜🎜##🎜🎜##🎜🎜##🎜🎜#
str_to_date( '2016-12-15 16:48:40', '%Y-%m-%d %H:%i:%S' )#🎜🎜##🎜🎜##🎜🎜#Alors MySQL peut-il obtenir le véritable horodatage ? bien sûr! #🎜🎜#rrreee#🎜🎜##🎜🎜#
#🎜🎜#2020-08-29 12:52:16.01#🎜🎜#2020-08-29 12 :52 :16.014057#🎜🎜##🎜🎜#Vous constaterez qu'il y a un point décimal à la fin et les nombres après le point décimal correspondront aux chiffres correspondants - c'est ce qu'on appelle des nanosecondes. #🎜🎜##🎜🎜##🎜🎜# se résume ainsi : #🎜🎜##🎜🎜##🎜🎜##🎜🎜##🎜🎜#
date
: seule date, non heure ; #🎜🎜##🎜🎜##🎜🎜##🎜🎜#datetime
: Il y a l'heure et la date ; code> time : uniquement l'heure, précise en minutes et secondes ; #🎜🎜##🎜🎜##🎜🎜##🎜🎜#timestamp
: horodatage, précis en minutes et secondes ; #🎜🎜 ##🎜🎜##🎜🎜##🎜🎜#year
: Année, par exemple 2002. S'il est écrit 2002-01-15, le calcul sera effectué et le résultat inséré sera 1986#🎜🎜## 🎜🎜##🎜🎜##🎜🎜#【2】Formatage du type de date et d'heure#🎜🎜##🎜🎜##🎜🎜# DATE_FORMAT( ) function#🎜🎜##🎜🎜# #🎜🎜#Vous pouvez utiliser la fonction date_format ( ) pour effectuer la conversion de l'heure. #🎜🎜#rrreee#🎜🎜##🎜🎜##🎜🎜#格式 | 描述 |
---|---|
%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 位 |
字符串转换为date:
str_to_date( '2016-12-15 16:48:40', '%Y-%m-%d %H:%i:%S' )
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!