欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MYSQL函數(shù)的使用梳理

 更新時(shí)間:2022年05月05日 09:35:58   作者:TimeFriends  
本篇文章講解是是MySQL的函數(shù)方法,涵蓋所有的MySQL常見的方法,MySQL函數(shù),是一種控制流程函數(shù),屬于數(shù)據(jù)庫用語言,以下列出了這些函數(shù)的說明

MYSQL函數(shù)

1:聚合函數(shù)

聚合函數(shù)主要由:count,sum,min,max,avg,group_count()

重點(diǎn)說一下group_count()函數(shù),首先根據(jù)group by指定的列進(jìn)行分組,并且用分隔符分隔,將同一個(gè)分組中的值連接起來,返回一個(gè)字符串結(jié)果. 

格式 : group_count([distinct]字段名 [order by 排序字段 asc/desc] [separator '分隔符'])

說明:

      1:使用distinct可以排除重復(fù)值.
      2:如果需要對(duì)結(jié)果值進(jìn)行排序,可以使用order by 子句.
      3:separator是一個(gè)字符串值,默認(rèn)為逗號(hào).

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

1:ABS(x) 返回x的絕對(duì)值
2:CEIL(x)返回大于等于x的最小整數(shù)(向上取整)
3:FLOOR(x) 返回小于等于x的最大整數(shù)(向下取整)
4:GREATEST(expr1,expr2...)返回列表中的最大值
5:LEAST(expr1,expr2.....)返回列表的最小值
6:MAX(x) 返回字段x的最大值
7:MIN(x) 返回字段x的最小值
8:MOD(x,y) 返回x除以y以后的余數(shù)
9:PI()返回圓周率(3.141593)
10:POW(x,y) 返回x的y次方
11:RAND() 返回0到1的隨機(jī)數(shù)
12:ROUND(x) 返回離x最近的整數(shù)(遵循四舍五入)
13:ROUND(x,y) 返回指定位數(shù)的小數(shù)(遵循四舍五入)
14:TRUNCATE(x,y) 返回?cái)?shù)值x保留到小數(shù)點(diǎn)后y位的值,(與ROUND最大的去區(qū)別是不會(huì)進(jìn)行四舍五入)

2:字符串函數(shù)

1:char_length(s) 返回字符串s的字符數(shù)
2:character_length 返回字符串s的字符數(shù)
3:concat(s1,s2,s3) 字符串s1,s2等多個(gè)字符串合并為一個(gè)字符串
4:concat_ws(x,s1,s2..) 同concat(s1,s2,s3)函數(shù),但是每個(gè)字符串之間要加上x,x可以是分隔符
5:field(s,s1,s2) 返回第一個(gè)字符串s在字符串列表(s1,s2..)中的位置
6:length() 返回的是字節(jié)數(shù) mysql中utf-8的編碼 一個(gè)中文漢字是三個(gè)字節(jié)
7:ltrim(s) 去掉字符串s開始處的空格 去除左邊的空格  rtrim()去除右邊的空格 trim()去除兩邊的空格
8:mid(s,n,len) 從字符串s的n位置截取長(zhǎng)度為len的子字符串同substring(s,n,len)
9:position(s1,in,s) 從字符串s中獲取s1的開始位置
10:replcae(s,s1,s2) 將字符串s2替代字符串s中的字符串s1
11:reverse(s) 將字符串s的順序反過來
12:right(s,n)返回字符串s的后n個(gè)字符(從右取n個(gè)字符)
13:strcmp(s1,s2) 比較字符串s1和s2,如果s1與s2相等返回0,如果s1>s2返回1 如果s1小于s2返回-1
14:substr(s,start,length) 從字符串s的start位置截取長(zhǎng)度為length的子字符串
15:ucase(s) upper(s)將字符串轉(zhuǎn)換為大寫
16:lcase(s) lower(s) 將字符串轉(zhuǎn)換為小寫

3:日期函數(shù)

1:unix_timestamp() 返回1970-01-01 00:00:00 到當(dāng)前毫秒值
2:unix_timestamp(date_string) 將指定日期轉(zhuǎn)換為毫秒值時(shí)間戳
3:from_unixtime(bigint unixtime,string-format) 將毫秒值時(shí)間戳轉(zhuǎn)為指定格式日期
4:curdate() 返回當(dāng)前日期
5:current_date() 返回當(dāng)前日期
6:current_timestamp() 返回當(dāng)前日期和時(shí)間
7:datediff(d1,d2) 計(jì)算日期d1>d2之間間隔的天數(shù)  eg:datediff('2022-01-01','2022-02-01')
8:currtime() 返回當(dāng)前時(shí)間 
9:date_format(d,f) 按照表達(dá)式f的要求顯示日期d

4:控制流函數(shù)

1:if(expr,v1,v2) 如果表達(dá)式expr成立,返回結(jié)果v1,否則返回結(jié)果v2
2:ifnull(v1,v2) 如果v1的值為null則返回v1,否則返回v2 
3:isnull(expression) 判斷表達(dá)式是否為null 
4:nullif(expr1,expr2)  比較兩個(gè)字符串 如果字符串expr1和expr2相等 返回null 否則返回expr1
5:case expression when condition1 then result1  when condition2 then result2 else result end 表示case函數(shù)開始,end表示函數(shù)結(jié)束,如果condition1成立則返回result1,如果condition2成立則返回result2,當(dāng)全部不成立則返回result,而當(dāng)有一個(gè)成立之后,后面的就不執(zhí)行了.

5:窗口函數(shù)

mysql8.0新增的窗口函數(shù)又稱為開窗函數(shù),非聚合窗口函數(shù)是相對(duì)于聚合函數(shù)來說,聚合函數(shù)是對(duì)一組數(shù)據(jù)計(jì)算后返回單個(gè)值(即分組),非聚合函數(shù)一次只會(huì)處理一行數(shù)據(jù),窗口聚合函數(shù)在行記錄上計(jì)算某個(gè)字段的結(jié)果時(shí),可將窗口范圍內(nèi)的數(shù)據(jù)輸入到聚合函數(shù)中,并不改變行數(shù)

5.1 序號(hào)函數(shù)

可以實(shí)現(xiàn)分組排序,并添加序號(hào)

1: row_number()
2: rank()
3: dense_rank() 

寫法:select id,...,dense_rank() over(partition by dname order by salary desc) as rn from employee;

注意: 不加 partition by 表示全局排序

5.2 分布函數(shù)

1: percent_rank()
  用途:每行按照公式(rank-1)/(row-1)進(jìn)行計(jì)算.其中rank為rank()函數(shù)產(chǎn)生的序號(hào),row為當(dāng)前窗口的記錄總行數(shù)
2: cume_dist()
  用途:分組內(nèi)小于,等于當(dāng)前rank值的行數(shù)/分組內(nèi)總行數(shù)
  應(yīng)用場(chǎng)景:查詢小于等于當(dāng)前薪資的比例

寫法:select dname,ename,salary,cume_dist() over(order by salary) as rn1,
cume_dist() over(partition by dname order by salary) as rn2 from employe;

5.3 前后函數(shù)

1: lag(expr,n)
2: lead(expr,n)

用途:返回位于當(dāng)前行的前n行(lag(exor,n))或后n行(lead(expr,n))的expr的值

應(yīng)用場(chǎng)景:查詢前1名同學(xué)的成績(jī)和當(dāng)前同學(xué)成績(jī)的差值 (當(dāng)前行內(nèi)可以有個(gè)上一行數(shù)據(jù)的某一字段值)

5.4 頭尾函數(shù)

1: first_value(expr)
2: last_value(expr)

用途:返回第一個(gè)(first_value(expr))或者最后一個(gè)(last_value(expr)) expr的值
應(yīng)用場(chǎng)景:截止到當(dāng)前,按照日期排序查詢第1個(gè)入職和最后一個(gè)入職員工的薪資

5.5 其他函數(shù)

1: nth_value(expr,n)
2: ntile(n)

用途:返回窗口中第n個(gè)expr的值,expr可以是表達(dá)式,也可以是列名
應(yīng)用場(chǎng)景:截止到當(dāng)前薪資,顯示每個(gè)員工的薪資中排名第二或者第三的薪資

5.6 開窗聚合函數(shù)

1: sum()
2: avg()
3: min()
4: max()

寫法:select id,...,sum(salary) over(partition by dname order by hiredate desc) as rn from employee;

每一行rn的數(shù)據(jù)是當(dāng)期行和之前每一行的salary之和
如果沒有order by排序語句,默認(rèn)把分組內(nèi)的所有數(shù)據(jù)進(jìn)行sum操作

到此這篇關(guān)于MYSQL函數(shù)的使用梳理的文章就介紹到這了,更多相關(guān)MYSQL函數(shù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • MYSQL updatexml()函數(shù)報(bào)錯(cuò)注入解析

    MYSQL updatexml()函數(shù)報(bào)錯(cuò)注入解析

    這篇文章主要介紹了MYSQL updatexml()函數(shù)報(bào)錯(cuò)注入解析,并且簡(jiǎn)單介紹了updatexml函數(shù),具有一定參考價(jià)值,需要的朋友可以了解下。
    2017-10-10
  • Mysql中文漢字轉(zhuǎn)拼音的實(shí)現(xiàn)(每個(gè)漢字轉(zhuǎn)換全拼)

    Mysql中文漢字轉(zhuǎn)拼音的實(shí)現(xiàn)(每個(gè)漢字轉(zhuǎn)換全拼)

    這篇文章主要介紹了Mysql中文漢字轉(zhuǎn)拼音的實(shí)現(xiàn),并且每個(gè)漢字會(huì)轉(zhuǎn)換全拼,使用Mysql自定義函數(shù)實(shí)現(xiàn),需要的朋友可以參考下
    2014-06-06
  • Mysql5.7.18版本(二進(jìn)制包安裝)自定義安裝路徑教程詳解

    Mysql5.7.18版本(二進(jìn)制包安裝)自定義安裝路徑教程詳解

    這篇文章主要介紹了Mysql5.7.18版本(二進(jìn)制包安裝)自定義安裝路徑教程詳解,需要的朋友可以參考下
    2017-07-07
  • Mysql升級(jí)到5.7后遇到的group by查詢問題解決

    Mysql升級(jí)到5.7后遇到的group by查詢問題解決

    這篇文章主要給大家介紹了關(guān)于Mysql升級(jí)到5.7后遇到的group by查詢問題的解決方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)同樣遇到這個(gè)問題的朋友們具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-09-09
  • win10家庭版64位下mysql 8.0.15 安裝配置方法圖文教程

    win10家庭版64位下mysql 8.0.15 安裝配置方法圖文教程

    這篇文章主要為大家詳細(xì)介紹了win10家庭版64位下mysql 8.0.15 安裝配置方法圖文教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-03-03
  • 小記一次mysql主從配置解決方案

    小記一次mysql主從配置解決方案

    mysql主從方案主要作用:讀寫分離,使數(shù)據(jù)庫能支撐更大的并發(fā)。在報(bào)表中尤其重要。由于部分報(bào)表sql語句非常的慢,導(dǎo)致鎖表,影響前臺(tái)服務(wù)。如果前臺(tái)使用master,報(bào)表使用slave,那么報(bào)表sql將不會(huì)造成前臺(tái)鎖,保證了前臺(tái)速度。
    2015-10-10
  • mysql中字符串截取與拆分的實(shí)現(xiàn)示例

    mysql中字符串截取與拆分的實(shí)現(xiàn)示例

    mysql 字符串截取與拆分在很多地方都可以用得到,本文主要介紹了mysql中字符串截取與拆分的實(shí)現(xiàn)示例,具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-12-12
  • MySQL問答系列之如何避免ibdata1文件大小暴漲

    MySQL問答系列之如何避免ibdata1文件大小暴漲

    MySql innodb如果是共享表空間,ibdata1文件會(huì)越來越大,所以下面這篇文章主要給大家介紹了關(guān)于MySQL問答系列之如何避免ibdata1文件大小暴漲的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2018-09-09
  • 如何添加一個(gè)mysql用戶并給予權(quán)限詳解

    如何添加一個(gè)mysql用戶并給予權(quán)限詳解

    在很多時(shí)候我們并不會(huì)直接利用mysql的root用戶進(jìn)行項(xiàng)目的開發(fā),一般我們都會(huì)創(chuàng)建一個(gè)具有部分權(quán)限的用戶,下面這篇文章主要給大家介紹了關(guān)于如何添加一個(gè)mysql用戶并給予權(quán)限的相關(guān)資料,需要的朋友可以參考下
    2023-03-03
  • Mysql常用函數(shù)大全(分類匯總講解)

    Mysql常用函數(shù)大全(分類匯總講解)

    今天小編就為大家分享一篇關(guān)于Mysql常用函數(shù)大全(分類匯總講解),小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧
    2019-03-03

最新評(píng)論