MySQL存儲過程的基本函數

(1).字符串類前端

CHARSET(str) //返回字串字符集
CONCAT (string2 [,... ]) //
鏈接字串
INSTR (string ,substring ) //
返回substring首次在string中出現的位置,不存在返回0
LCASE (string2 ) //
轉換成小寫

LEFT (string2 ,length ) //
string2中的左邊起取length個字符
LENGTH (string ) //string
長度
LOAD_FILE (file_name ) //
從文件讀取內容
LOCATE (substring , string [,start_position ] )
 INSTR,但可指定開始位置
LPAD (string2 ,length ,pad ) //
重複用pad加在string開頭,直到字串長度爲length
LTRIM (string2 ) //
去除前端空格

REPEAT (string2 ,count ) //
重複count
REPLACE (str ,search_str ,replace_str ) //
str中用replace_str替換search_str
RPAD (string2 ,length ,pad) //
str後用pad補充,直到長度爲
length
RTRIM (string2 ) //
去除後端空格

STRCMP (string1 ,string2 ) //
逐字符比較兩字串大小,
SUBSTRING (str , position [,length ]) //
strposition開始,length個字符
,
注:mysql中處理字符串時,默認第一個字符下標爲1,即參數position必須大於等於1
 mysql

 

  1. mysql> select substring('abcd',0,2);  sql

  2. +-----------------------+  後端

  3. substring('abcd',0,2) |  ide

  4. +-----------------------+  編碼

  5. |                       |  spa

  6. +-----------------------+  code

  7. 1 row in set (0.00 sec)  orm

  8.  

  9. mysql> select substring('abcd',1,2);  ci

  10. +-----------------------+  

  11. substring('abcd',1,2) |  

  12. +-----------------------+  

  13. |     ab                |  

  14. +-----------------------+  

  15. 1 row in set (0.02 sec)  

TRIM([[BOTH|LEADING|TRAILING] [padding] FROM]string2) //去除指定位置的指定字符
UCASE (string2 ) //
轉換成大寫
RIGHT(string2,length) //
string2最後length個字符
SPACE(count) //
生成count個空格

(2).數學類

ABS (number2 ) //絕對值
BIN (decimal_number ) //
十進制轉二進制
CEILING (number2 ) //
向上取整
CONV(number2,from_base,to_base) //
進制轉換
FLOOR (number2 ) //
向下取整
FORMAT (number,decimal_places ) //
保留小數位數
HEX (DecimalNumber ) //
轉十六進制
注:HEX()中可傳入字符串,則返回其ASC-11,如HEX('DEF')返回4142143
也能夠傳入十進制整數,返回其十六進制編碼,如HEX(25)返回
19
LEAST (number , number2 [,..]) //
求最小值

MOD (numerator ,denominator ) //
求餘
POWER (number ,power ) //
求指數
RAND([seed]) //
隨機數
ROUND (number [,decimals ]) //
四捨五入,decimals爲小數位數]

注:返回類型並不是均爲整數,如:
(1)
默認變爲×××值

  1. mysql> select round(1.23);  

  2. +-------------+  

  3. | round(1.23) |  

  4. +-------------+  

  5. |           1 |  

  6. +-------------+  

  7. 1 row in set (0.00 sec)  

  8.  

  9. mysql> select round(1.56);  

  10. +-------------+  

  11. | round(1.56) |  

  12. +-------------+  

  13. |           2 |  

  14. +-------------+  

  15. 1 row in set (0.00 sec) 



(2)
能夠設定小數位數,返回浮點型數據

  1. mysql> select round(1.567,2);  

  2. +----------------+  

  3. | round(1.567,2) |  

  4. +----------------+  

  5. |           1.57 |  

  6. +----------------+  

  7. 1 row in set (0.00 sec) 

SIGN (number2 ) //

 

(3).日期時間類

ADDTIME (date2 ,time_interval ) //time_interval加到date2
CONVERT_TZ (datetime2 ,fromTZ ,toTZ ) //
轉換時區
CURRENT_DATE ( ) //
當前日期
CURRENT_TIME ( ) //
當前時間
CURRENT_TIMESTAMP ( ) //
當前時間戳
DATE (datetime ) //
返回datetime的日期部分
DATE_ADD (date2 , INTERVAL d_value d_type ) //
date2中加上日期或時間
DATE_FORMAT (datetime ,FormatCodes ) //
使用formatcodes格式顯示datetime
DATE_SUB (date2 , INTERVAL d_value d_type ) //
date2上減去一個時間
DATEDIFF (date1 ,date2 ) //
兩個日期差
DAY (date ) //
返回日期的天
DAYNAME (date ) //
英文星期
DAYOFWEEK (date ) //
星期(1-7) ,1爲星期天
DAYOFYEAR (date ) //
一年中的第幾天
EXTRACT (interval_name FROM date ) //
date中提取日期的指定部分
MAKEDATE (year ,day ) //
給出年及年中的第幾天,生成日期串
MAKETIME (hour ,minute ,second ) //
生成時間串
MONTHNAME (date ) //
英文月份名
NOW ( ) //
當前時間
SEC_TO_TIME (seconds ) //
秒數轉成時間
STR_TO_DATE (string ,format ) //
字串轉成時間,format格式顯示
TIMEDIFF (datetime1 ,datetime2 ) //
兩個時間差
TIME_TO_SEC (time ) //
時間轉秒數]
WEEK (date_time [,start_of_week ]) //
第幾周
YEAR (datetime ) //
年份
DAYOFMONTH(datetime) //
月的第幾天
HOUR(datetime) //
小時
LAST_DAY(date) //date
的月的最後日期
MICROSECOND(datetime) //
微秒
MONTH(datetime) //

MINUTE(datetime) //
返回符號,正負或0
SQRT(number2) //
開平方

相關文章
相關標籤/搜索