真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

mysql時間類型怎么用 mysql數(shù)據(jù)庫時間類型

mysql時間類型的用法及股票知識的學(xué)習(xí)?

mysql時間類型的用法,給你轉(zhuǎn)一篇日期函數(shù)說明,你看看就知道了,股票知識,太高深了,不在研究范圍之內(nèi)

創(chuàng)新互聯(lián)主營蕪湖網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營網(wǎng)站建設(shè)方案,app開發(fā)定制,蕪湖h5微信平臺小程序開發(fā)搭建,蕪湖網(wǎng)站營銷推廣歡迎蕪湖等地區(qū)企業(yè)咨詢

MySQL 獲得當(dāng)前日期時間 函數(shù)

1.1 獲得當(dāng)前日期+時間(date + time)函數(shù):now()

mysql select now();

+---------------------+

| now() |

+---------------------+

| 2008-08-08 22:20:46 |

+---------------------+

除了 now() 函數(shù)能獲得當(dāng)前的日期時間外,MySQL 中還有下面的函數(shù):

current_timestamp()

,current_timestamp

,localtime()

,localtime

,localtimestamp -- (v4.0.6)

,localtimestamp() -- (v4.0.6)

這些日期時間函數(shù),都等同于 now()。鑒于 now() 函數(shù)簡短易記,建議總是使用 now() 來替代上面列出的函數(shù)。

1.2 獲得當(dāng)前日期+時間(date + time)函數(shù):sysdate()

sysdate() 日期時間函數(shù)跟 now() 類似,不同之處在于:now() 在執(zhí)行開始時值就得到了, sysdate() 在函數(shù)執(zhí)行時動態(tài)得到值??聪旅娴睦泳兔靼琢耍?/p>

mysql select now(), sleep(3), now();

+---------------------+----------+---------------------+

| now() | sleep(3) | now() |

+---------------------+----------+---------------------+

| 2008-08-08 22:28:21 | 0 | 2008-08-08 22:28:21 |

+---------------------+----------+---------------------+mysql select sysdate(), sleep(3), sysdate();

+---------------------+----------+---------------------+

| sysdate() | sleep(3) | sysdate() |

+---------------------+----------+---------------------+

| 2008-08-08 22:28:41 | 0 | 2008-08-08 22:28:44 |

+---------------------+----------+---------------------+

可以看到,雖然中途 sleep 3 秒,但 now() 函數(shù)兩次的時間值是相同的; sysdate() 函數(shù)兩次得到的時間值相差 3 秒。MySQL Manual 中是這樣描述 sysdate() 的:Return the time at which the function executes。

sysdate() 日期時間函數(shù),一般情況下很少用到。

2. 獲得當(dāng)前日期(date)函數(shù):curdate()

mysql select curdate();

+------------+

| curdate() |

+------------+

| 2008-08-08 |

+------------+

其中,下面的兩個日期函數(shù)等同于 curdate():

current_date()

,current_date

3. 獲得當(dāng)前時間(time)函數(shù):curtime()

mysql select curtime();

+-----------+

| curtime() |

+-----------+

| 22:41:30 |

+-----------+

其中,下面的兩個時間函數(shù)等同于 curtime():

current_time()

,current_time

4. 獲得當(dāng)前 UTC 日期時間函數(shù):utc_date(), utc_time(), utc_timestamp()

mysql select utc_timestamp(), utc_date(), utc_time(), now()

+---------------------+------------+------------+---------------------+

| utc_timestamp() | utc_date() | utc_time() | now() |

+---------------------+------------+------------+---------------------+

| 2008-08-08 14:47:11 | 2008-08-08 | 14:47:11 | 2008-08-08 22:47:11 |

+---------------------+------------+------------+---------------------+

因?yàn)槲覈挥跂|八時區(qū),所以本地時間 = UTC 時間 + 8 小時。UTC 時間在業(yè)務(wù)涉及多個國家和地區(qū)的時候,非常有用。

二、MySQL 日期時間 Extract(選?。?函數(shù)。

1. 選取日期時間的各個部分:日期、時間、年、季度、月、日、小時、分鐘、秒、微秒

set @dt = '2008-09-10 07:15:30.123456';

select date(@dt); -- 2008-09-10

select time(@dt); -- 07:15:30.123456

select year(@dt); -- 2008

select quarter(@dt); -- 3

select month(@dt); -- 9

select week(@dt); -- 36

select day(@dt); -- 10

select hour(@dt); -- 7

select minute(@dt); -- 15

select second(@dt); -- 30

select microsecond(@dt); -- 123456

2. MySQL Extract() 函數(shù),可以上面實(shí)現(xiàn)類似的功能:

set @dt = '2008-09-10 07:15:30.123456';

select extract(year from @dt); -- 2008

select extract(quarter from @dt); -- 3

select extract(month from @dt); -- 9

select extract(week from @dt); -- 36

select extract(day from @dt); -- 10

select extract(hour from @dt); -- 7

select extract(minute from @dt); -- 15

select extract(second from @dt); -- 30

select extract(microsecond from @dt); -- 123456select extract(year_month from @dt); -- 200809

select extract(day_hour from @dt); -- 1007

select extract(day_minute from @dt); -- 100715

select extract(day_second from @dt); -- 10071530

select extract(day_microsecond from @dt); -- 10071530123456

select extract(hour_minute from @dt); -- 715

select extract(hour_second from @dt); -- 71530

select extract(hour_microsecond from @dt); -- 71530123456

select extract(minute_second from @dt); -- 1530

select extract(minute_microsecond from @dt); -- 1530123456

select extract(second_microsecond from @dt); -- 30123456

MySQL Extract() 函數(shù)除了沒有date(),time() 的功能外,其他功能一應(yīng)具全。并且還具有選取‘day_microsecond’ 等功能。注意這里不是只選取 day 和 microsecond,而是從日期的 day 部分一直選取到 microsecond 部分。夠強(qiáng)悍的吧!

MySQL Extract() 函數(shù)唯一不好的地方在于:你需要多敲幾次鍵盤。

3. MySQL dayof… 函數(shù):dayofweek(), dayofmonth(), dayofyear()

分別返回日期參數(shù),在一周、一月、一年中的位置。

set @dt = '2008-08-08';

select dayofweek(@dt); -- 6

select dayofmonth(@dt); -- 8

select dayofyear(@dt); -- 221

日期 ‘2008-08-08′ 是一周中的第 6 天(1 = Sunday, 2 = Monday, …, 7 = Saturday);一月中的第 8 天;一年中的第 221 天。

4. MySQL week… 函數(shù):week(), weekofyear(), dayofweek(), weekday(), yearweek()

set @dt = '2008-08-08';

select week(@dt); -- 31

select week(@dt,3); -- 32

select weekofyear(@dt); -- 32

select dayofweek(@dt); -- 6

select weekday(@dt); -- 4

select yearweek(@dt); -- 200831

MySQL week() 函數(shù),可以有兩個參數(shù),具體可看手冊。 weekofyear() 和 week() 一樣,都是計(jì)算“某天”是位于一年中的第幾周。 weekofyear(@dt) 等價于 week(@dt,3)。

MySQL weekday() 函數(shù)和 dayofweek() 類似,都是返回“某天”在一周中的位置。不同點(diǎn)在于參考的標(biāo)準(zhǔn), weekday:(0 = Monday, 1 = Tuesday, …, 6 = Sunday); dayofweek:(1 = Sunday, 2 = Monday, …, 7 = Saturday)

MySQL yearweek() 函數(shù),返回 year(2008) + week 位置(31)。

5. MySQL 返回星期和月份名稱函數(shù):dayname(), monthname()

set @dt = '2008-08-08';

select dayname(@dt); -- Friday

select monthname(@dt); -- August

思考,如何返回中文的名稱呢?

6. MySQL last_day() 函數(shù):返回月份中的最后一天。

select last_day('2008-02-01'); -- 2008-02-29

select last_day('2008-08-08'); -- 2008-08-31

MySQL last_day() 函數(shù)非常有用,比如我想得到當(dāng)前月份中有多少天,可以這樣來計(jì)算:

mysql select now(), day(last_day(now())) as days;

+---------------------+------+

| now() | days |

+---------------------+------+

| 2008-08-09 11:45:45 | 31 |

+---------------------+------+ 三、MySQL 日期時間計(jì)算函數(shù)

1. MySQL 為日期增加一個時間間隔:date_add()

set @dt = now();

select date_add(@dt, interval 1 day); -- add 1 day

select date_add(@dt, interval 1 hour); -- add 1 hour

select date_add(@dt, interval 1 minute); -- ...

select date_add(@dt, interval 1 second);

select date_add(@dt, interval 1 microsecond);

select date_add(@dt, interval 1 week);

select date_add(@dt, interval 1 month);

select date_add(@dt, interval 1 quarter);

select date_add(@dt, interval 1 year);select date_add(@dt, interval -1 day); -- sub 1 day

MySQL adddate(), addtime()函數(shù),可以用 date_add() 來替代。下面是 date_add() 實(shí)現(xiàn) addtime() 功能示例:

mysql set @dt = '2008-08-09 12:12:33';

mysql

mysql select date_add(@dt, interval '01:15:30' hour_second);

+------------------------------------------------+

| date_add(@dt, interval '01:15:30' hour_second) |

+------------------------------------------------+

| 2008-08-09 13:28:03 |

+------------------------------------------------+mysql select date_add(@dt, interval '1 01:15:30' day_second);

+-------------------------------------------------+

| date_add(@dt, interval '1 01:15:30' day_second) |

+-------------------------------------------------+

| 2008-08-10 13:28:03 |

+-------------------------------------------------+

date_add() 函數(shù),分別為 @dt 增加了“1小時 15分 30秒” 和 “1天 1小時 15分 30秒”。建議:總是使用 date_add() 日期時間函數(shù)來替代 adddate(), addtime()。

2. MySQL 為日期減去一個時間間隔:date_sub()

mysql select date_sub('1998-01-01 00:00:00', interval '1 1:1:1' day_second);

+----------------------------------------------------------------+

| date_sub('1998-01-01 00:00:00', interval '1 1:1:1' day_second) |

+----------------------------------------------------------------+

| 1997-12-30 22:58:59 |

+----------------------------------------------------------------+

MySQL date_sub() 日期時間函數(shù) 和 date_add() 用法一致,不再贅述。另外,MySQL 中還有兩個函數(shù) subdate(), subtime(),建議,用 date_sub() 來替代。

3. MySQL 另類日期函數(shù):period_add(P,N), period_diff(P1,P2)

函數(shù)參數(shù)“P” 的格式為“YYYYMM” 或者 “YYMM”,第二個參數(shù)“N” 表示增加或減去 N month(月)。

MySQL period_add(P,N):日期加/減去N月。

mysql select period_add(200808,2), period_add(20080808,-2)

+----------------------+-------------------------+

| period_add(200808,2) | period_add(20080808,-2) |

+----------------------+-------------------------+

| 200810 | 20080806 |

+----------------------+-------------------------+

MySQL period_diff(P1,P2):日期 P1-P2,返回 N 個月。

mysql select period_diff(200808, 200801);

+-----------------------------+

| period_diff(200808, 200801) |

+-----------------------------+

| 7 |

+-----------------------------+

在 MySQL 中,這兩個日期函數(shù),一般情況下很少用到。

4. MySQL 日期、時間相減函數(shù):datediff(date1,date2), timediff(time1,time2)

MySQL datediff(date1,date2):兩個日期相減 date1 - date2,返回天數(shù)。

select datediff('2008-08-08', '2008-08-01'); -- 7

select datediff('2008-08-01', '2008-08-08'); -- -7

MySQL timediff(time1,time2):兩個日期相減 time1 - time2,返回 time 差值。

select timediff('2008-08-08 08:08:08', '2008-08-08 00:00:00'); -- 08:08:08

select timediff('08:08:08', '00:00:00'); -- 08:08:08

注意:timediff(time1,time2) 函數(shù)的兩個參數(shù)類型必須相同。

四、MySQL 日期轉(zhuǎn)換函數(shù)、時間轉(zhuǎn)換函數(shù)

1. MySQL (時間、秒)轉(zhuǎn)換函數(shù):time_to_sec(time), sec_to_time(seconds)

select time_to_sec('01:00:05'); -- 3605

select sec_to_time(3605); -- '01:00:05'

2. MySQL (日期、天數(shù))轉(zhuǎn)換函數(shù):to_days(date), from_days(days)

select to_days('0000-00-00'); -- 0

select to_days('2008-08-08'); -- 733627select from_days(0); -- '0000-00-00'

select from_days(733627); -- '2008-08-08'

3. MySQL Str to Date (字符串轉(zhuǎn)換為日期)函數(shù):str_to_date(str, format)

select str_to_date('08/09/2008', '%m/%d/%Y'); -- 2008-08-09

select str_to_date('08/09/08' , '%m/%d/%y'); -- 2008-08-09

select str_to_date('08.09.2008', '%m.%d.%Y'); -- 2008-08-09

select str_to_date('08:09:30', '%h:%i:%s'); -- 08:09:30

select str_to_date('08.09.2008 08:09:30', '%m.%d.%Y %h:%i:%s'); -- 2008-08-09 08:09:30

可以看到,str_to_date(str,format) 轉(zhuǎn)換函數(shù),可以把一些雜亂無章的字符串轉(zhuǎn)換為日期格式。另外,它也可以轉(zhuǎn)換為時間。“format” 可以參看 MySQL 手冊。

4. MySQL Date/Time to Str(日期/時間轉(zhuǎn)換為字符串)函數(shù):date_format(date,format), time_format(time,format)

mysql select date_format('2008-08-08 22:23:00', '%W %M %Y');

+------------------------------------------------+

| date_format('2008-08-08 22:23:00', '%W %M %Y') |

+------------------------------------------------+

| Friday August 2008 |

+------------------------------------------------+mysql select date_format('2008-08-08 22:23:01', '%Y%m%d%H%i%s');

+----------------------------------------------------+

| date_format('2008-08-08 22:23:01', '%Y%m%d%H%i%s') |

+----------------------------------------------------+

| 20080808222301 |

+----------------------------------------------------+mysql select time_format('22:23:01', '%H.%i.%s');

+-------------------------------------+

| time_format('22:23:01', '%H.%i.%s') |

+-------------------------------------+

| 22.23.01 |

+-------------------------------------+

MySQL 日期、時間轉(zhuǎn)換函數(shù):date_format(date,format), time_format(time,format) 能夠把一個日期/時間轉(zhuǎn)換成各種各樣的字符串格式。它是 str_to_date(str,format) 函數(shù)的 一個逆轉(zhuǎn)換。

5. MySQL 獲得國家地區(qū)時間格式函數(shù):get_format()

MySQL get_format() 語法:

get_format(date|time|datetime, 'eur'|'usa'|'jis'|'iso'|'internal'

MySQL get_format() 用法的全部示例:

select get_format(date,'usa') ; -- '%m.%d.%Y'

select get_format(date,'jis') ; -- '%Y-%m-%d'

select get_format(date,'iso') ; -- '%Y-%m-%d'

select get_format(date,'eur') ; -- '%d.%m.%Y'

select get_format(date,'internal') ; -- '%Y%m%d'

select get_format(datetime,'usa') ; -- '%Y-%m-%d %H.%i.%s'

select get_format(datetime,'jis') ; -- '%Y-%m-%d %H:%i:%s'

select get_format(datetime,'iso') ; -- '%Y-%m-%d %H:%i:%s'

select get_format(datetime,'eur') ; -- '%Y-%m-%d %H.%i.%s'

select get_format(datetime,'internal') ; -- '%Y%m%d%H%i%s'

select get_format(time,'usa') ; -- '%h:%i:%s %p'

select get_format(time,'jis') ; -- '%H:%i:%s'

select get_format(time,'iso') ; -- '%H:%i:%s'

select get_format(time,'eur') ; -- '%H.%i.%s'

select get_format(time,'internal') ; -- '%H%i%s'

MySQL get_format() 函數(shù)在實(shí)際中用到機(jī)會的比較少。

6. MySQL 拼湊日期、時間函數(shù):makdedate(year,dayofyear), maketime(hour,minute,second)

select makedate(2001,31); -- '2001-01-31'

select makedate(2001,32); -- '2001-02-01'select maketime(12,15,30); -- '12:15:30' 五、MySQL 時間戳(Timestamp)函數(shù)

1. MySQL 獲得當(dāng)前時間戳函數(shù):current_timestamp, current_timestamp()

mysql select current_timestamp, current_timestamp();

+---------------------+---------------------+

| current_timestamp | current_timestamp() |

+---------------------+---------------------+

| 2008-08-09 23:22:24 | 2008-08-09 23:22:24 |

+---------------------+---------------------+

2. MySQL (Unix 時間戳、日期)轉(zhuǎn)換函數(shù):

unix_timestamp(),

unix_timestamp(date),

from_unixtime(unix_timestamp),

from_unixtime(unix_timestamp,format)

下面是示例:

select unix_timestamp(); -- 1218290027

select unix_timestamp('2008-08-08'); -- 1218124800

select unix_timestamp('2008-08-08 12:30:00'); -- 1218169800select from_unixtime(1218290027); -- '2008-08-09 21:53:47'

select from_unixtime(1218124800); -- '2008-08-08 00:00:00'

select from_unixtime(1218169800); -- '2008-08-08 12:30:00'select from_unixtime(1218169800, '%Y %D %M %h:%i:%s %x'); -- '2008 8th August 12:30:00 2008'

3. MySQL 時間戳(timestamp)轉(zhuǎn)換、增、減函數(shù):

timestamp(date) -- date to timestamp

timestamp(dt,time) -- dt + time

timestampadd(unit,interval,datetime_expr) --

timestampdiff(unit,datetime_expr1,datetime_expr2) --

請看示例部分:

select timestamp('2008-08-08'); -- 2008-08-08 00:00:00

select timestamp('2008-08-08 08:00:00', '01:01:01'); -- 2008-08-08 09:01:01

select timestamp('2008-08-08 08:00:00', '10 01:01:01'); -- 2008-08-18 09:01:01select timestampadd(day, 1, '2008-08-08 08:00:00'); -- 2008-08-09 08:00:00

select date_add('2008-08-08 08:00:00', interval 1 day); -- 2008-08-09 08:00:00

MySQL timestampadd() 函數(shù)類似于 date_add()。

select timestampdiff(year,'2002-05-01','2001-01-01'); -- -1

select timestampdiff(day ,'2002-05-01','2001-01-01'); -- -485

select timestampdiff(hour,'2008-08-08 12:00:00','2008-08-08 00:00:00'); -- -12

select datediff('2008-08-08 12:00:00', '2008-08-01 00:00:00'); -- 7

MySQL timestampdiff() 函數(shù)就比 datediff() 功能強(qiáng)多了,datediff() 只能計(jì)算兩個日期(date)之間相差的天數(shù)。

六、MySQL 時區(qū)(timezone)轉(zhuǎn)換函數(shù)convert_tz(dt,from_tz,to_tz)select convert_tz('2008-08-08 12:00:00', '+08:00', '+00:00'); -- 2008-08-08 04:00:00

時區(qū)轉(zhuǎn)換也可以通過 date_add, date_sub, timestampadd 來實(shí)現(xiàn)。

select date_add('2008-08-08 12:00:00', interval -8 hour); -- 2008-08-08 04:00:00

select date_sub('2008-08-08 12:00:00', interval 8 hour); -- 2008-08-08 04:00:00

select timestampadd(hour, -8, '2008-08-08 12:00:00'); -- 2008-08-08 04:00:00

為了您的安全,請只打開來源可靠的網(wǎng)址

打開網(wǎng)站 取消

來自:

MySql建表時日期類型的出理

mysql(5.5)所支持的日期時間類型有:DATETIME、?TIMESTAMP、DATE、TIME、YEAR。

1.DATETIME 用于表示 年月日 時分秒,是 DATE 和 TIME 的組合,并且記錄的年份比較長久。如果實(shí)際應(yīng)用中有這樣的需求,就可以使用 DATETIME 類型。

2.TIMESTAMP

TIMESTAMP 用于表示 年月日 時分秒,但是記錄的年份比較短暫。

TIMESTAMP 和時區(qū)相關(guān),更能反映當(dāng)前時間。當(dāng)插入日期時,會先轉(zhuǎn)換為本地時區(qū)后再存放;當(dāng)查詢?nèi)掌跁r,會將日期轉(zhuǎn)換為本地時區(qū)后再顯示。所以不同時區(qū)的人看到的同一時間是? 不一樣的。

表中的第一個?TIMESTAMP?列自動設(shè)置為系統(tǒng)時間(CURRENT_TIMESTAMP)。當(dāng)插入或更新一行,但沒有明確給 TIMESTAMP 列賦值,也會自動設(shè)置為當(dāng)前系統(tǒng)時間。如果表中有第二個 TIMESTAMP 列,則默認(rèn)值設(shè)置為0000-00-00 00:00:00。

TIMESTAMP 的屬性受 Mysql 版本和服務(wù)器 SQLMode 的影響較大。

如果記錄的日期需要讓不同時區(qū)的人使用,最好使用 TIMESTAMP。

3.DATE

DATE 用于表示 年月日,如果實(shí)際應(yīng)用值需要保存 年月日 就可以使用 DATE。

4.TIME

TIME 用于表示 時分秒,如果實(shí)際應(yīng)用值需要保存 時分秒 就可以使用 TIME。

5.YEAR

YEAR 用于表示 年份,YEAR 有 2 位(最好使用4位)和 4 位格式的年。 默認(rèn)是4位。如果實(shí)際應(yīng)用只保存年份,那么用 1 bytes 保存 YEAR 類型完全可以。不但能夠節(jié)約存儲空間,還能提高表的操作效率。

資料拓展:

每種日期時間類型都有一個有效值范圍,如果超出這個范圍,在默認(rèn)的SQLMode下會報(bào)錯,并以零值存儲。

插入或更新時,日期時間類型允許“不嚴(yán)格”語法,以DATETIME為例(其他日期時間類型雷同):

YYYY-MM-DD HH:MM:SS?或?YY-MM-DD HH:MM:SS 格式的字符串。任何符號都可以用作日期部分或時間部分的間隔符。例如:“14-06-18 14:54:10”、“14*06*18 14.54.10”、“14+06+18 14=54=10”是等價的。對于包含日期時間的字符串值,如果月、日、時、分、秒的值小于10,不需要指定兩位數(shù)。例如:“2014-2-3 2:3:6”、“2014-02-03 02:03:06”是等價的。

YYYYMMDDHHMMSS 或?YYMMDDHHMMSS 格式的字符串。如果字符串對于日期時間類型是合法的就可以解釋為日期時間類型。例如:“20140618145410” 和 “140618145410”將被解釋為 “2014-06-18 14:54:10” ,但是?“20140618145480” 是不合法的(秒數(shù)不合法),將被解釋為 “0000-00-00 00:00:00”。

YYYYMMDDHHMMSS 或?YYMMDDHHMMSS 格式的數(shù)字。如果該數(shù)字對日期時間類型是合法的就可以解釋為日期時間類型。例如:“20140618145410” 和 “140618145410” 將被解釋為 “2014-06-18 14:54:10” 。數(shù)值的長度應(yīng)為6、8、12、14。如果數(shù)值長度是 8 或 14 位長,則假定為 YYYYMMDD 或?YYYYMMDDHHMMSS?格式。如果數(shù)值為 6 或 12 位長,則假定為 YYMMDD 或?YYMMDDHHMMSS?格式。

MySQL:一文弄懂時區(qū)&time_zone

你還在被以下問題困擾嗎:

MySQL的安裝規(guī)范中應(yīng)該設(shè)置什么時區(qū)?

JAVA應(yīng)用讀取到的時間和北京時間差了14個小時,為什么?怎么解決?

已經(jīng)運(yùn)行一段時間的業(yè)務(wù),修改MySQL的時區(qū)會影響已經(jīng)存儲的時間類型數(shù)據(jù)嗎?

遷移數(shù)據(jù)時會有導(dǎo)致時間類型數(shù)據(jù)時區(qū)錯誤的可能嗎?

...

看完這篇文章,你能解決上面所有的疑惑。首先出場的是和時區(qū)相關(guān)的啟動參數(shù)和系統(tǒng)變量。

如果要在 MySQL 啟動時就指定時區(qū),則應(yīng)該使用啟動參數(shù): default-time-zone ,示例:

啟動后我們可以看到控制時區(qū)的系統(tǒng)變量,其中 time_zone 變量控制時區(qū),在MySQL運(yùn)行時可以通過 set 命令修改(注意:不可以寫在 my點(diǎn)吸煙 f 中):

啟動參數(shù)和系統(tǒng)變量的可用值遵循相同的格式:

system_time_zone 變量只有全局值沒有會話值,不能動態(tài)修改,MySQL 啟動時,將嘗試自動確定服務(wù)器的時區(qū),并使用它來設(shè)置 system_time_zone 系統(tǒng)變量, 此后該值不變。當(dāng) time_zone='system' 時,就是使用的這個時區(qū),示例中 time_zone 就是 CST,而 CST 在 RedHat 上就是東八區(qū):

概括一下就兩點(diǎn):

不僅是select now(),包括insert .. values(now())、以及字段的 DEFAULT CURRENT_TIMESTAMP 屬性也受此影響:

timestamp 數(shù)據(jù)類型會存儲當(dāng)時session的時區(qū)信息,讀取時會根據(jù)當(dāng)前 session 的時區(qū)進(jìn)行轉(zhuǎn)換;而 datetime 數(shù)據(jù)類型插入的是什么值,再讀取就是什么值,不受時區(qū)影響。也可以理解為已經(jīng)存儲的數(shù)據(jù)是不會變的,只是 timestamp 類型數(shù)據(jù)在讀取時會根據(jù)時區(qū)轉(zhuǎn)換:

關(guān)于時區(qū)所有明面上的東西都在上面了,我們前面提到的困擾就是在暗處的經(jīng)驗(yàn)。

1. MySQL的安裝規(guī)范中應(yīng)該設(shè)置什么時區(qū)?

對于國內(nèi)的業(yè)務(wù)了,在 my點(diǎn)吸煙 f 寫入 default-time-zone='+08:00' ,其他地區(qū)和開發(fā)確認(rèn)取對應(yīng)時區(qū)即可。

為什么不設(shè)置為 system 呢?使用系統(tǒng)時間看起來也是個不錯的選擇,比較省事。不建議的原因有兩點(diǎn):

2. JAVA應(yīng)用讀取到的時間和北京時間差了14個小時,為什么?怎么解決?

這通常是 JDBC 參數(shù)中沒有為連接設(shè)置時區(qū)屬性(用 serverTimezone 參數(shù)指定),并且MySQL中沒有設(shè)置全局時區(qū),這樣MySQL默認(rèn)使用的是系統(tǒng)時區(qū),即 CST。這樣一來應(yīng)用與MySQL 建立的連接的 session time_zone 為 CST ,前面我們提到 CST 在 RedHat 上是 +08:00 時區(qū),但其實(shí)它一共能代表4個時區(qū):

JDBC在解析CST時使用了美國標(biāo)準(zhǔn)時間,這就會導(dǎo)致時區(qū)錯誤。要解決也簡單:一是遵守上面剛說到的規(guī)范,對MySQL顯式地設(shè)置'+08:00'時區(qū);二是JDBC設(shè)置正確的 serverTimezone。

3. 已經(jīng)運(yùn)行一段時間的業(yè)務(wù),修改MySQL的時區(qū)會影響已經(jīng)存儲的時間類型數(shù)據(jù)嗎?

完全不會,只會影響對 timestamp 數(shù)據(jù)類型的讀取。這里不得不提一句,為啥要用 timestamp?用 datetime 不香嗎,范圍更大,存儲空間其實(shí)差別很小,趕緊加到開發(fā)規(guī)范中吧。

4. 遷移數(shù)據(jù)時會有導(dǎo)致時間類型數(shù)據(jù)時區(qū)錯誤的可能嗎?

這個還真有。

如何避免?mysqldump 也提供了一個參數(shù) --skip-tz-utc ,意思就是導(dǎo)出數(shù)據(jù)的那個連接不設(shè)置 UTC 時區(qū),使用 MySQL 的 global time_zone 系統(tǒng)變量值。

其實(shí) mysqldump 導(dǎo)出 sql 文件時默認(rèn)也是使用 UTC 時區(qū),并且會在導(dǎo)出的 sql 文件頭部帶有 session time_zone 信息,這樣可以保證導(dǎo) SQL 文件導(dǎo)入和導(dǎo)出時使用相同的時區(qū),從而保證數(shù)據(jù)的時區(qū)正確(而導(dǎo)出的 csv 文件顯然不可以攜帶此信息)。需要注意的是 --compact 參數(shù)會去掉 sql 文件的所有頭信息,所以一定要記得: --compact 參數(shù)得和 --skip-tz-utc 一起使用。


新聞名稱:mysql時間類型怎么用 mysql數(shù)據(jù)庫時間類型
本文來源:http://weahome.cn/article/ddsjssc.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部