新聞中心
這篇文章將為大家詳細講解有關(guān)mysql函數(shù)的示例分析,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
一.內(nèi)置函數(shù)
1.數(shù)學(xué)函數(shù)
rand() | round(num) | ceil(num) | floor(num) |
---|---|---|---|
隨機 | 四舍五入 | 向上取整 | 向下取整 |
2.字符串函數(shù)
length() 字節(jié)長度
char_length() 字符長度
ucase() 大寫
lcase() 小寫
concat(字符,…,字符n) 連接字符串
replace(字符串,舊字符,新字符)字符串替換
截取字符串
left(字符串,截取長度)
right(字符串,截取長度)
substring(字符串,開始位置,截取長度) #包含開始位置
mysql> select left('123456',4); +------------------+ | left('123456',4) | +------------------+ | 1234 | +------------------+ 1 row in set (0.00 sec) mysql> select right('123456',4); +-------------------+ | right('123456',4) | +-------------------+ | 3456 | +-------------------+ 1 row in set (0.00 sec) mysql> select substring('123456',2,4); +-------------------------+ | substring('123456',2,4) | +-------------------------+ | 2345 | +-------------------------+ 1 row in set (0.00 sec)
3.日期函數(shù)
now() | unix_timestamp() | from_unixtime() |
---|---|---|
當前時間 | 時間戳 | 格式化時間戳 |
mysql> select now(); +---------------------+ | now() | +---------------------+ | 2019-03-16 14:55:42 | +---------------------+ 1 row in set (0.00 sec) mysql> select unix_timestamp(); +------------------+ | unix_timestamp() | +------------------+ | 1552719356 | +------------------+ 1 row in set (0.00 sec) mysql> select from_unixtime(1552719356); +---------------------------+ | from_unixtime(1552719356) | +---------------------------+ | 2019-03-16 14:55:56 | +---------------------------+ 1 row in set (0.00 sec)
year() | month() | day() | hour() | minute() | second() |
---|---|---|---|---|---|
年 | 月 | 日 | 時 | 分 | 秒 |
mysql> select -> year(now()) as '年', -> month(now()) as '月', -> day(now()) as '日', -> hour(now()) as '時', -> minute(now()) as '分', -> second(now()) as '秒'; +------+------+------+------+------+------+ | 年 | 月 | 日 | 時 | 分 | 秒 | +------+------+------+------+------+------+ | 2019 | 3 | 16 | 14 | 59 | 12 | +------+------+------+------+------+------+
4.加密函數(shù)
md5(數(shù)據(jù))
password(數(shù)據(jù))
5.條件判斷函數(shù)
1).語法: if(數(shù)據(jù),值1,值2) #判斷指定數(shù)據(jù)是否為真:真-值1,假-值2
mysql> select if(null,1,2); +--------------+ | if(null,1,2) | +--------------+ | 2 | +--------------+ 1 row in set (0.00 sec) mysql> select if(1,0,2); +-----------+ | if(1,0,2) | +-----------+ | 0 | +-----------+ 1 row in set (0.00 sec)
2).語法: IFNULL(數(shù)據(jù),值2) #判斷指定數(shù)據(jù)是否為null:null-值2,非null-本身
mysql> select ifnull(0,123); +---------------+ | ifnull(0,123) | +---------------+ | 0 | +---------------+ 1 row in set (0.00 sec) mysql> select ifnull('a',123); +-----------------+ | ifnull('a',123) | +-----------------+ | a | +-----------------+ 1 row in set (0.00 sec)
二.自定義函數(shù)
語法:
#修改結(jié)束符 delimiter // create function 函數(shù)名(參數(shù)名 類型,...,參數(shù)名n 類型n) returns 返回數(shù)據(jù)類型 begin #SQL語句 return 返回值; end // delimiter ; #調(diào)用 select 函數(shù)名();
輸出"hello world"(不帶參數(shù)的函數(shù))
#判斷函數(shù)是否存在,存在就刪除 drop function if exists f1; delimiter // create function f1() returns varchar(30) begin return 'hello world'; end // delimiter ; select f1(); +-------------+ | f1() | +-------------+ | hello world | +-------------+
傳遞兩個整型求和(帶參數(shù)的函數(shù))
drop function if exists f2; delimiter // create function f2(num1 int, num2 int) returns int begin return num1 + num2; end // delimiter ; select f2(8, 2); +----------+ | f2(8, 2) | +----------+ | 10 | +----------+
三.自定義函數(shù)相關(guān)語法
顯示所有的函數(shù):show function status\G #輸出的內(nèi)容很多
刪除函數(shù):drop function [if exists] 函數(shù)名;
四.存儲過程和函數(shù)的區(qū)別
存儲過程可以返回多個值,而自定義函數(shù)只能返回一個值
存儲過程一般獨立執(zhí)行,而函數(shù)往往作為其他SQL語句的一部分來使用
關(guān)于“mysql函數(shù)的示例分析”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。
名稱欄目:mysql函數(shù)的示例分析-創(chuàng)新互聯(lián)
文章鏈接:http://fisionsoft.com.cn/article/djpioj.html