程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> Mysql中日期和時光函數運用不消求人

Mysql中日期和時光函數運用不消求人

編輯:MySQL綜合教程

Mysql中日期和時光函數運用不消求人。本站提示廣大學習愛好者:(Mysql中日期和時光函數運用不消求人)文章只能為提供參考,不一定能成為您想要的結果。以下是Mysql中日期和時光函數運用不消求人正文


1、從MYSQL官方下載MYSQL的源碼版本【必定如果源碼版本】
2、按以下代碼鍵入LINUX敕令行

[注] 添加mysql組和用戶
#groupadd mysql
#useradd -g mysql mysql
[注] 解包到/usr/local
# tar -xzf mysql-standard-4.1.9-pc-linux-gnu-i686.tar.gz -C /usr/local
[注] 樹立軟鏈接,便利操作(此處給此銜接定名為mysql001,也可為其它的名字)
#cd /usr/local
#ln -s mysql-standard-5.0.15-linux-i686-glibc23 mysql001
#cd mysql001
#scripts/mysql_install_db
#chown -R root .
#chown -R mysql data
#chgrp -R mysql .
[注] 復制data,以供單版本多實例分派
#cp -a data data_1
#cp -a data data_2
[注] 添加多實例設置裝備擺設文件
#cd /usr/local/mysql001/bin
#cat >my_multi.cnf
[注] 以下是my_multi.cnf的設置裝備擺設信息,可依此復制
[mysqld_multi]
mysqld = /usr/local/mysql001/bin/mysqld_safe
mysqladmin = /usr/local/mysql001/bin/mysqladmin
user = root
password = root
[mysqld1]
socket = /tmp/mysql_001.sock
port = 3301
pid-file = /usr/local/mysql001/data_1/hostname.pid
datadir = /usr/local/mysql001/data_1
log = /usr/local/mysql001/data_1/hostname.log
user = mysql
# slave setting
server-id = 2
master-host = 192.168.1.85
master-port = 3306
master-user = backup
master-password = 123456
replicate-do-db = gs_database
replicate-do-db = gs_log
master-connect-retry=30
[mysqld2]
socket = /tmp/mysql_5_2.sock
port = 3302
pid-file = /usr/local/mysql001/data_2/hostname.pid
datadir = /usr/local/mysql001/data_2
log = /usr/local/mysql001/data_2/hostname.log
user = mysql
# slave setting
server-id = 3
master-host = 192.168.1.69
master-port = 3306
master-user = backup
master-password = 123
replicate-do-db = gs_databaes
replicate-do-db = gs_log
master-connect-retry=30

CTRL+D加入。

#vi /etc/profile # 添加體系情況變量。
export MYSQL_HOME=/usr/local/mysql001/bin
export PATH=$PATH:$MYSQL_HOME

重啟體系讓情況變量失效。
添加至開機主動啟動【此處可不添加,依小我情形決議能否須要設置開機主動啟動】

vi /etc/rc.local
# 添加
mysqld_multi --defaults-extra-file=/usr/local/src/mysql_dir/bin/my_multi.cnf start 1,2

3、其它一些技能
# 拜訪某個實例:
mysql -u root -S /tmp/mysql_5_1.sock -p

# 設置各個實例暗碼:
mysqladmin -u root password 'root' -S /tmp/mysql_5_1.sock

# 手動啟動各個實例:
mysqld_multi --defaults-extra-file=/usr/local/src/mysql_dir/bin/my_multi.cnf start 1,2

# 停滯各個實例:
mysqld_multi --defaults-extra-file=/usr/local/src/mysql_dir/bin/my_multi.cnf stop 1,2

# 參考文章
http://blog.liuts.com/post/13/

因為第一次接觸LINUX,花了三地利間才算有所造詣,收回來願望可以給年夜伙帶來便利 expr type)
 
SUBDATE(date,INTERVAL expr type)

這些功效履行日期運算。關於MySQL 3.22,他們是新的。ADDDATE()和SUBDATE()是DATE_ADD()和DATE_SUB()的同義詞。
在MySQL 3.23中,你可使用+和-而不是DATE_ADD()和DATE_SUB()。(見例子)date是一個指定開端日期的
DATETIME或DATE值,expr是指定加到開端日期或從開端日期減去的距離值一個表達式,expr是一個字符串;它可以以
一個“-”開端表現負距離。type是一個症結詞,指明表達式應當若何被說明。EXTRACT(type FROM date)函數從日期
中前往“type”距離。下表顯示了type和expr參數如何被聯系關系: type值 寄義 希冀的expr格局
SECOND 秒 SECONDS
MINUTE 分鐘 MINUTES
HOUR 時光 HOURS
DAY 天 DAYS
MONTH 月 MONTHS
YEAR 年 YEARS
MINUTE_SECOND 分鐘和秒 "MINUTES:SECONDS"
HOUR_MINUTE 小時和分鐘 "HOURS:MINUTES"
DAY_HOUR 天和小時 "DAYS HOURS"
YEAR_MONTH 年和月 "YEARS-MONTHS"
HOUR_SECOND 小時, 分鐘, "HOURS:MINUTES:SECONDS"
DAY_MINUTE 天, 小時, 分鐘 "DAYS HOURS:MINUTES"
DAY_SECOND 天, 小時, 分鐘, 秒 "DAYS HOURS:MINUTES:SECONDS"

MySQL在expr格局中許可任何標點分隔符。表現顯示的是建議的分隔符。假如date參數是一個DATE值而且你的盤算僅僅
包括YEAR、MONTH和DAY部門(即,沒有時光部門),成果是一個DATE值。不然成果是一個DATETIME值。

mysql> SELECT "1997-12-31 23:59:59" + INTERVAL 1 SECOND;
-> 1998-01-01 00:00:00
mysql> SELECT INTERVAL 1 DAY + "1997-12-31";
-> 1998-01-01
mysql> SELECT "1998-01-01" - INTERVAL 1 SECOND;
-> 1997-12-31 23:59:59
mysql> SELECT DATE_ADD("1997-12-31 23:59:59",
INTERVAL 1 SECOND);
-> 1998-01-01 00:00:00
mysql> SELECT DATE_ADD("1997-12-31 23:59:59",
INTERVAL 1 DAY);
-> 1998-01-01 23:59:59
mysql> SELECT DATE_ADD("1997-12-31 23:59:59",
INTERVAL "1:1" MINUTE_SECOND);
-> 1998-01-01 00:01:00
mysql> SELECT DATE_SUB("1998-01-01 00:00:00",
INTERVAL "1 1:1:1" DAY_SECOND);
-> 1997-12-30 22:58:59
mysql> SELECT DATE_ADD("1998-01-01 00:00:00",
INTERVAL "-1 10" DAY_HOUR);
-> 1997-12-30 14:00:00
mysql> SELECT DATE_SUB("1998-01-02", INTERVAL 31 DAY);
-> 1997-12-02
mysql> SELECT EXTRACT(YEAR FROM "1999-07-02");
-> 1999
mysql> SELECT EXTRACT(YEAR_MONTH FROM "1999-07-02 01:02:03");
-> 199907
mysql> SELECT EXTRACT(DAY_MINUTE FROM "1999-07-02 01:02:03");
-> 20102

假如你指定太短的距離值(不包含type症結詞希冀的距離部門),MySQL假定你免卻了距離值的最左臉部分。例如,
假如你指定一個type是DAY_SECOND,值expr被願望有天、小時、分鐘和秒部門。假如你象"1:10"如許指定值,
MySQL假定日子和小時部門是喪失的而且值代表分鐘和秒。換句話說,"1:10" DAY_SECOND以它等價於"1:10" MINUTE_SECOND
的方法說明,這對那MySQL說明TIME值表現經由的時光而非作為一天的時光的方法有二義性。假如你應用確切不准確的日期,
成果是NULL。假如你增長MONTH、YEAR_MONTH或YEAR而且成果日期年夜於新月份的最年夜值天數,日子在新月用最年夜的天調劑。

mysql> select DATE_ADD('1998-01-30', Interval 1 month);
-> 1998-02-28

留意,早年面的例子中詞INTERVAL和type症結詞不是辨別年夜小寫的。
TO_DAYS(date)
給出一個日期date,前往一個天數(從0年的天數)。
mysql> select TO_DAYS(950501);
-> 728779
mysql> select TO_DAYS('1997-10-07');
-> 729669

TO_DAYS()不盤算用於應用格列高裡歷(1582)湧現前的值。

FROM_DAYS(N)
給出一個天數N,前往一個DATE值。
mysql> select FROM_DAYS(729669);
-> '1997-10-07'

TO_DAYS()不盤算用於應用格列高裡歷(1582)湧現前的值。

DATE_FORMAT(date,format)
依據format字符串格局化date值。以下潤飾符可以被用在format字符串中: %M 月名字(January……December)
%W 禮拜名字(Sunday……Saturday)
%D 有英語前綴的月份的日期(1st, 2nd, 3rd, 等等。)
%Y 年, 數字, 4 位
%y 年, 數字, 2 位
%a 縮寫的禮拜名字(Sun……Sat)
%d 月份中的天數, 數字(00……31)
%e 月份中的天數, 數字(0……31)
%m 月, 數字(01……12)
%c 月, 數字(1……12)
%b 縮寫的月份名字(Jan……Dec)
%j 一年中的天數(001……366)
%H 小時(00……23)
%k 小時(0……23)
%h 小時(01……12)
%I 小時(01……12)
%l 小時(1……12)
%i 分鐘, 數字(00……59)
%r 時光,12 小時(hh:mm:ss [AP]M)
%T 時光,24 小時(hh:mm:ss)
%S 秒(00……59)
%s 秒(00……59)
%p AM或PM
%w 一個禮拜中的天數(0=Sunday ……6=Saturday )
%U 禮拜(0……52), 這裡禮拜天是禮拜的第一天
%u 禮拜(0……52), 這裡禮拜一是禮拜的第一天
%% 一個文字“%”。

一切的其他字符不做說明被復制到成果中。

mysql> select DATE_FORMAT('1997-10-04 22:23:00', '%W %M %Y');
-> 'Saturday October 1997'
mysql> select DATE_FORMAT('1997-10-04 22:23:00', '%H:%i:%s');
-> '22:23:00'
mysql> select DATE_FORMAT('1997-10-04 22:23:00',
'%D %y %a %d %m %b %j');
-> '4th 97 Sat 04 10 Oct 277'
mysql> select DATE_FORMAT('1997-10-04 22:23:00',
'%H %k %I %r %T %S %w');
-> '22 22 10 10:23:00 PM 22:23:00 00 6'
MySQL3.23中,在格局潤飾符字符前須要%。在MySQL更早的版本中,%是可選的。
TIME_FORMAT(time,format)
這象下面的DATE_FORMAT()函數一樣應用,然則format字符串只能包括處置小時、分鐘和秒的那些格局潤飾符。
其他潤飾符發生一個NULL值或0。
CURDATE()
 
CURRENT_DATE
以'YYYY-MM-DD'或YYYYMMDD格局前往明天日期值,取決於函數是在一個字符串照樣數字高低文被應用。
mysql> select CURDATE();
-> '1997-12-15'
mysql> select CURDATE() + 0;
-> 19971215

CURTIME()
 
CURRENT_TIME
以'HH:MM:SS'或HHMMSS格局前往以後時光值,取決於函數是在一個字符串照樣在數字的高低文被應用。
mysql> select CURTIME();
-> '23:50:26'
mysql> select CURTIME() + 0;
-> 235026

NOW()
 
SYSDATE()
 
CURRENT_TIMESTAMP
以'YYYY-MM-DD HH:MM:SS'或YYYYMMDDHHMMSS格局前往以後的日期和時光,取決於函數是在一個字符串照樣在數字的
高低文被應用。
mysql> select NOW();
-> '1997-12-15 23:50:26'
mysql> select NOW() + 0;
-> 19971215235026

UNIX_TIMESTAMP()
 
UNIX_TIMESTAMP(date)
假如沒有參數挪用,前往一個Unix時光戳記(從'1970-01-01 00:00:00'GMT開端的秒數)。假如UNIX_TIMESTAMP()用一
個date參數被挪用,它前往從'1970-01-01 00:00:00' GMT開端的秒數值。date可所以一個DATE字符串、一個DATETIME
字符串、一個TIMESTAMP或以YYMMDD或YYYYMMDD格局的當地時光的一個數字。
mysql> select UNIX_TIMESTAMP();
-> 882226357
mysql> select UNIX_TIMESTAMP('1997-10-04 22:23:00');
-> 875996580

當UNIX_TIMESTAMP被用於一個TIMESTAMP列,函數將直接接收值,沒有隱含的“string-to-unix-timestamp”變換。

FROM_UNIXTIME(unix_timestamp)
以'YYYY-MM-DD HH:MM:SS'或YYYYMMDDHHMMSS格局前往unix_timestamp參數所表現的值,取決於函數是在一個字符串
照樣或數字高低文中被應用。
mysql> select FROM_UNIXTIME(875996580);
-> '1997-10-04 22:23:00'
mysql> select FROM_UNIXTIME(875996580) + 0;
-> 19971004222300

FROM_UNIXTIME(unix_timestamp,format)
前往表現 Unix 時光標志的一個字符串,依據format字符串格局化。format可以包括與DATE_FORMAT()函數列出的條
目異樣的潤飾符。
mysql> select FROM_UNIXTIME(UNIX_TIMESTAMP(),
'%Y %D %M %h:%i:%s %x');
-> '1997 23rd December 03:43:30 x'

SEC_TO_TIME(seconds)
前往seconds參數,變換成小時、分鐘和秒,值以'HH:MM:SS'或HHMMSS格局化,取決於函數是在一個字符串照樣在數字
高低文中被應用。
mysql> select SEC_TO_TIME(2378);
-> '00:39:38'
mysql> select SEC_TO_TIME(2378) + 0;
-> 3938

TIME_TO_SEC(time)
前往time參數,轉換成秒。
mysql> select TIME_TO_SEC('22:23:00');
-> 80580
mysql> select TIME_TO_SEC('00:39:38');
-> 2378
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved