MySQL常見內(nèi)置函數(shù)以及其使用教程
1、聚合函數(shù)
| 函數(shù) | 說明 |
COUNT([DISTINCT] expr) | 返回查詢到的數(shù)據(jù)的 數(shù)量 |
SUM([DISTINCT] expr) | 返回查詢到的數(shù)據(jù)的 總和,不是數(shù)字沒有意義 |
AVG([DISTINCT] expr) | 返回查詢到的數(shù)據(jù)的 平均值,不是數(shù)字沒有意義 |
MAX([DISTINCT] expr) | 返回查詢到的數(shù)據(jù)的 最大值,不是數(shù)字沒有意義 |
MIN([DISTINCT] expr) | 返回查詢到的數(shù)據(jù)的 最小值,不是數(shù)字沒有意義 |
實(shí)例:
準(zhǔn)備工作,創(chuàng)建一個(gè)雇員信息表(來自 oracle 9i 的經(jīng)典測(cè)試表)
- EMP員工表
- DEPT部門表
- SALGRADE工資等級(jí)表
統(tǒng)計(jì)公司員工人數(shù)
select count(*) from emp;

統(tǒng)計(jì)公司每月發(fā)放薪資
select sum(sal) from emp;

統(tǒng)計(jì)員工月平均薪資
select avg(sal) 平均月薪 from emp;

統(tǒng)計(jì)員工最高月薪
select max(sal) 最高月薪 from emp;

2、日期函數(shù)
| 函數(shù)名稱 | 描述 |
| current_date() | 當(dāng)前日期 |
| current_time() | 當(dāng)前時(shí)間 |
| current_timestamp() | 當(dāng)前時(shí)間戳 |
| date(datetime) | 返回datetime參數(shù)的日期部分 |
| date_add(date, interval d_value_type) | 在date中添加日期或時(shí)間,interval數(shù)值單位可以是year,minute,second,day |
| date_sub(date, interval d_value_type) | 在date中減去日期或時(shí)間,interval數(shù)值單位可以是year,minute,second,day |
| datediff(date1, date2) | 兩個(gè)日期的差,單位是天 |
| now() | 當(dāng)前日期時(shí)間 |
實(shí)例:
獲得年月日、獲得時(shí)分秒、獲得時(shí)間戳

在日期的基礎(chǔ)上加日期、計(jì)算兩個(gè)日期之間相差多少天

3、字符串函數(shù)
| 函數(shù) | 說明 |
| charset(str) | 返回字符串字符集 |
| concat(string [,...]) | 連接字符串 |
| instr(string, substring) | 返回substring在string中出現(xiàn)的位置,沒有返回0 |
| ucase(string) | 轉(zhuǎn)換成大寫 |
| lcase(string) | 轉(zhuǎn)換成小寫 |
| left(string, length) | 從string中的左邊起取length個(gè)字符 |
| length(string) | string的長度 |
| replace(str, search_str, replace_str) | 在str中用replace_str替換search_str |
| strcmp(string1, string2) | 逐字符比較兩字符串大小 |
| substring(str, position [,length]) | 從str的position開始,取length個(gè)字符 |
| ltrim(string) rtrim(string) trim(string) | 去除前空格或后空格 |
實(shí)例:
獲取 emp 表的 ename 列的字符集
select charset(ename) from emp;
要求顯示emp表中的員工薪資信息,顯示格式:"某某的崗位是:,的部門是: ,的月薪是: "。
select concat(ename,' 的崗位是: ', job,' 的部門是: ', deptno,' 的月薪是: ', sal) as 員工信息 from emp limit 2;

截取emp表中ename字段的第二個(gè)到第三個(gè)字符
select substring(ename, 2, 2), ename from emp;
以首字母小寫的方式顯示所有員工的姓名
select concat(lcase(substring(ename, 1, 1)),substring(ename,2)) from EMP;
4、數(shù)學(xué)函數(shù)
| 函數(shù) | 說明 |
| abs(number) | 絕對(duì)值函數(shù) |
| bin(decimal_number) | 十進(jìn)制轉(zhuǎn)換二進(jìn)制 |
| hex(decimal_number) | 轉(zhuǎn)換成十六進(jìn)制 |
| conv(number, from_base, to_base) | 進(jìn)制轉(zhuǎn)換 |
| ceiling(number) | 向上取整 |
| floor(number) | 向下取整 |
| format(number, decimal_places) | 格式化,保留小數(shù)位數(shù) |
| hex(decimal_number) | 轉(zhuǎn)換成十六進(jìn)制 |
| rand() | 返回隨機(jī)浮點(diǎn)數(shù),范圍[0.0, 1.0] |
| mod(number, denominator) | 取模,求余 |
絕對(duì)值,向上取整,兩位小數(shù)

5、其它函數(shù)
user() 查詢當(dāng)前用戶
select user();
md5(str)對(duì)一個(gè)字符串進(jìn)行md5摘要,摘要后得到一個(gè)32位字符串
select md5('asd');

database()顯示當(dāng)前正在使用的數(shù)據(jù)庫
select database();
password()函數(shù),MySQL數(shù)據(jù)庫使用該函數(shù)對(duì)用戶加密
select password('root');
ifnull(val1, val2) 如果val1為null,返回val2,否則返回val1的值

總結(jié)
到此這篇關(guān)于MySQL常見內(nèi)置函數(shù)以及其使用的文章就介紹到這了,更多相關(guān)MySQL常見內(nèi)置函數(shù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
MySQL啟動(dòng)時(shí)InnoDB引擎被禁用了的解決方法
最近在工作中遇到一個(gè)問題,現(xiàn)將解決的方法分享出來供大家參考學(xué)習(xí),下面這篇文章主要給大家介紹了關(guān)于MySQL啟動(dòng)時(shí)InnoDB引擎被禁用了的解決方法,需要的朋友們下面跟著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2017-08-08
淺談Mysql中類似于nvl()函數(shù)的ifnull()函數(shù)
下面小編就為大家?guī)硪黄獪\談Mysql中類似于nvl()函數(shù)的ifnull()函數(shù)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-02-02
MySQL里實(shí)現(xiàn)類似SPLIT的分割字符串的函數(shù)
SQL對(duì)字符串的處理能力比較弱,比如我要循環(huán)遍歷象1,2,3,4,5這樣的字符串,如果用數(shù)組的話,遍歷很簡單,但是T-SQL不支持?jǐn)?shù)組,所以處理下來比較麻煩2012-09-09
MYSQL?SQL查詢近7天一個(gè)月的數(shù)據(jù)的操作方法
這篇文章主要介紹了MYSQL?SQL查詢近7天一個(gè)月的數(shù)據(jù)的操作方法,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-04-04
lnmp關(guān)閉mysql日志保護(hù)硬盤空間的方法
這篇文章主要介紹了lnmp關(guān)閉mysql日志保護(hù)硬盤空間的方法,需要的朋友可以參考下2014-02-02
查看本地MYSQL數(shù)據(jù)庫IP地址的三種方法
本文介紹了多種方法來查看連接到本地MySQL服務(wù)器的IP地址,括使用SQL查詢從`information_schema.processlist`獲取IP地址,并通過`group by`進(jìn)行統(tǒng)計(jì),以及通過命令行工具如`mysql`和`awk`進(jìn)行過濾和計(jì)數(shù),這些方法有助于監(jiān)控和管理數(shù)據(jù)庫連接,需要的朋友可以參考下2024-10-10

