日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

10.数据库中的内置函数

發(fā)布時(shí)間:2024/7/5 数据库 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 10.数据库中的内置函数 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

字符串函數(shù)

查看字符的ascii碼值ascii(str),str是空串時(shí)返回0

查看ascii碼值對(duì)應(yīng)的字符char(數(shù)字):select char(97);
拼接字符串concat(str1,str2...):selectconcat(12,34,'ab');
包含字符個(gè)數(shù)length(str):selectlength('abc');

截取字符串

left(str,len)返回字符串str的左端len個(gè)字符

right(str,len)返回字符串str的右端len個(gè)字符

substring(str,pos,len)返回字符串str的位置pos起len個(gè)字符

select substring('abc123',2,3);

去除空格

ltrim(str)返回刪除了左空格的字符串str

rtrim(str)返回刪除了右空格的字符串str

trim([方向remstr from str)返回從某側(cè)刪除remstr后的字符串str,方向詞包括both、leading、trailing,表示兩側(cè)、左、右

select trim('?bar?? ');
select trim(leading 'x' FROM 'xxxbarxxx');
select trim(both 'x' FROM 'xxxbarxxx');
select trim(trailing 'x' FROM 'xxxbarxxx');

返回由n個(gè)空格字符組成的一個(gè)字符串space(n):select space(10);
替換字符串replace(str,from_str,to_str)

大小寫轉(zhuǎn)換,函數(shù)如下lower(str)、upper(str)

?

數(shù)學(xué)函數(shù)

求絕對(duì)值A(chǔ)BS(n)的select abs(-32);
求米除以?的余數(shù)模(M,N),同運(yùn)算符%:selectmod(10,3);select 10%3;
地板地板(n)時(shí),表示不大于?的最大整數(shù):selectfloor(2.3);
天花板的天花板(n)時(shí),表示不小于?的最大整數(shù):selectceiling(2.3);

求四舍五入值輪(N,D)中,n表示原數(shù),D表示小數(shù)位置,默認(rèn)為0

select round(1.6);

求X的y次冪POW(X,Y):select pow(2,3);

獲取圓周率PI():select PI();

隨機(jī)數(shù)RAND(),值為0-1.0的浮點(diǎn)數(shù):select rand();

?

日期時(shí)間函數(shù)

獲取子值,值為整數(shù)類型,函數(shù)如下

年(日)返回日期的年份(范圍在1000到9999)

月(日)返回日期中的月份數(shù)值

日(日)返回日期中的日期數(shù)值

小時(shí)(時(shí)間)返回時(shí)間的小時(shí)數(shù)(范圍是0到23)

分鐘(時(shí)間)返回時(shí)間的分鐘數(shù)(范圍是0到59)

第二(時(shí)間)返回時(shí)間的秒數(shù)(范圍是0到59)

select year('2016-12-21');

日期計(jì)算,使用+- 運(yùn)算符,數(shù)字后面的關(guān)鍵字為年,月,日,時(shí),分,秒

select '2016-12-21'+interval 1 day;

日期格式化DATE_FORMAT(日期,格式)

參數(shù)格式可選值如下

%Y 獲取年,返回完整年份
%y 獲取年,返回簡(jiǎn)寫年份
%m 獲取月,返回月份
%d 獲取日,返回天值
%H 獲取時(shí),返回24進(jìn)制的小時(shí)數(shù)
%h 獲取時(shí),返回12進(jìn)制的小時(shí)數(shù)
%i 獲取分,返回分鐘數(shù)
%s 獲取秒,返回秒數(shù)

示例如下:將使用- 拼接的日期轉(zhuǎn)換為使用空格拼接

select date_format('2016-12-21','%Y %m %d');

當(dāng)前日期CURRENT_DATE()select current_date();
當(dāng)前時(shí)間的current_time()selectcurrent_time();
現(xiàn)在當(dāng)前日期時(shí)間()select now();

?

類型轉(zhuǎn)換函數(shù)

有投和轉(zhuǎn)換兩個(gè)函數(shù)

語法如下:

cast(value as type)
convert(value, type)

值表示要轉(zhuǎn)換的值,鍵入表示目標(biāo)類型

目標(biāo)類型如下:

二進(jìn)制二進(jìn)制

字符型炭,可指定字符個(gè)數(shù)如炭(10)

日期日期

時(shí)間時(shí)間

日期時(shí)間型日期時(shí)間

浮點(diǎn)數(shù)小數(shù)

整數(shù)簽署

無符號(hào)整數(shù)無符號(hào)

SELECTCONVERT('125.83',SIGNED);SELECT CAST('125.83' AS signed);

?

流程控制

類似于python中的if語句,進(jìn)行選擇判斷

case語法1:等值判斷

說明:當(dāng)值等于某個(gè)比較值的時(shí)候,對(duì)應(yīng)的結(jié)果會(huì)被返回;如果所有的比較值都不相等則返回else的結(jié)果;如果沒有else并且所有比較值都不相等則返回null

case when 比較值1 then 結(jié)果1when 比較值2 then 結(jié)果2... else 結(jié)果 end
例:
select case 1 when 1 then 'one' when 2 then 'two' else 'zero' end as result;

case語法2:非等值判斷,可以進(jìn)行 > 、<、!=等判斷

說明:當(dāng)某個(gè)條件返回true時(shí),對(duì)應(yīng)的結(jié)果被返回;如果所有的條件都不返回true則返回else的結(jié)果;如果沒有else并且所有條件都不返回true則返回null

case when 條件1then 結(jié)果1 when 條件2 then 結(jié)果2... else 結(jié)果 end
例:
select case when 1 > 2 then 'part1' when 3 > 2 then 'part2' else 'part3'end as result;

if語句,說明:如果表達(dá)式的結(jié)果為true,則返回結(jié)果1,否則返回結(jié)果2

if(表達(dá)式,結(jié)果1,結(jié)果2)
例:select if(1 > 2,2,3) as result;

ifnull語句,說明:如果表達(dá)式1不為null,則返回表達(dá)式1的結(jié)果,否則返回表達(dá)式2的結(jié)果

ifnull(表達(dá)式1,表達(dá)式2)
例:select ifnull(1,0) as result;

nullif語句,說明:如果表達(dá)式1等于表達(dá)式2,則返回null,否則返回表達(dá)式1的結(jié)果

nullif(表達(dá)式1,表達(dá)式2)
例:select nullif(1,0) as result;

?

?

總結(jié)

以上是生活随笔為你收集整理的10.数据库中的内置函数的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。