溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

MySQL函數(shù)有哪些

發(fā)布時(shí)間:2021-04-12 13:07:38 來源:億速云 閱讀:190 作者:小新 欄目:MySQL數(shù)據(jù)庫(kù)

小編給大家分享一下MySQL函數(shù)有哪些,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

MySQL函數(shù)有哪些

MySQL函數(shù)

  • 常用函數(shù)

  • 聚合函數(shù)

  • 數(shù)據(jù)庫(kù)級(jí)別的MD5加密

常用函數(shù)

函數(shù)作用例子
ABS(x)返回x的絕對(duì)值SELECT ABS(-1) – 返回1
CEIL(x),CEILING(x)返回大于或等于x的最小整數(shù)SELECT CEIL(1.5) – 返回2
FLOOR(x)返回小于或等于x的最大整數(shù)SELECT FLOOR(1.5) – 返回1
RAND()返回0->1的隨機(jī)數(shù)SELECT RAND() --0.6264973735683573
RAND(x)返回0->1的隨機(jī)數(shù),x值相同時(shí)返回的隨機(jī)數(shù)相同SELECT RAND(2) – 1.5865798029924
SIGN(x)返回x的符號(hào),x是負(fù)數(shù)、0、正數(shù)分別返回-1、0和1SELECT SIGN(-10) – (-1)
PI()返回圓周率(3.141593)SELECT PI()– 3.141593
TRUNCATE(x,y)返回?cái)?shù)值x保留到小數(shù)點(diǎn)后y位的值(與ROUND最大的區(qū)別是不會(huì)進(jìn)行四舍五入)SELECT TRUNCATE(1.23456,3) – 1.234
ROUND(x)返回離x最近的整數(shù)SELECT ROUND(1.23456) – 1
ROUND(x,y)保留x小數(shù)點(diǎn)后y位的值,但截?cái)鄷r(shí)要進(jìn)行四舍五入SELECT ROUND(1.23456,3) – 1.235
POW(x,y).POWER(x,y)返回x的y次方SELECT POW(2,3) – 8
SQRT(x)返回x的平方根SELECT SQRT(25) – 5
EXP(x)返回e的x次方SELECT EXP(3) – 20.085536923188
MOD(x,y)返回x除以y以后的余數(shù)SELECT MOD(5,2) – 1
LOG(x)返回自然對(duì)數(shù)(以e為底的對(duì)數(shù))SELECT LOG(20.085536923188) – 3
LOG10(x)返回以10為底的對(duì)數(shù)SELECT LOG10(100) – 2
RADIANS(x)將角度轉(zhuǎn)換為弧度SELECT RADIANS(180) – 3.1415926535898
DEGREES(x)將弧度轉(zhuǎn)換為角度SELECT DEGREES(3.1415926535898) – 180
SIN(x)求正弦值(參數(shù)是弧度)SELECT SIN(RADIANS(30)) – 0.5
ASIN(x)求反正弦值(參數(shù)是弧度)
COS(x)求余弦值(參數(shù)是弧度)SELECT COS(RADIANS(30)) --0.5
ACOS(x)求反余弦值(參數(shù)是弧度)
TAN(x)求正切值(參數(shù)是弧度)SELECT TAN(RADIANS(45)) --1
ATAN(x) ATAN2(x)求反正切值(參數(shù)是弧度)
COT(x)求余切值(參數(shù)是弧度)
-- 數(shù)學(xué)運(yùn)算SELECT ABS(-8) as 絕對(duì)值 -- 絕對(duì)值SELECT CEILING(9.4) -- 向上取整SELECT FLOOR(9.4)  -- 向下取整SELECT RAND()	-- 返回一個(gè) 0-1 之間的隨機(jī)數(shù)SELECT SIGN(-10)  -- 返回一個(gè)數(shù)的符號(hào)	0 返回 0  負(fù)數(shù)返回-1	正數(shù)返回 1

相關(guān)免費(fèi)學(xué)習(xí)推薦:mysql視頻教程

函數(shù)作用例子
CHAR_LENGTH(s)返回字符串s的字符數(shù)SELECT CHAR_LENGTH(‘你好123’) – 5
LENGTH(s)返回字符串s的長(zhǎng)度SELECT LENGTH(‘你好123’) – 9
CONCAT(s1,s2,…)將字符串s1,s2等多個(gè)字符串合并為一個(gè)字符串SELECT CONCAT(‘12’,‘34’) – 1234
INSERT(s1,x,len,s2)將字符串s2替換s1的x位置開始長(zhǎng)度為len的字符串SELECT INSERT(‘12345’,1,3,‘a(chǎn)bc’) – abc45
UPPER(s),UCAASE(S)將字符串s的所有字母變成大寫字母SELECT UPPER(‘a(chǎn)bc’) – ABC
LOWER(s),LCASE(s)將字符串s的所有字母變成小寫字母SELECT LOWER(‘ABC’) – abc
LEFT(s,n)返回字符串s的前n個(gè)字符SELECT LEFT(‘a(chǎn)bcde’,2) – ab
RIGHT(s,n)返回字符串s的后n個(gè)字符SELECT RIGHT(‘a(chǎn)bcde’,2) – de
LPAD(s1,len,s2)字符串s2來填充s1的開始處,使字符串長(zhǎng)度達(dá)到lenSELECT LPAD(‘a(chǎn)bc’,5,‘xx’) – xxabc
RPAD(s1,len,s2)字符串s2來填充s1的結(jié)尾處,使字符串的長(zhǎng)度達(dá)到lenSELECT RPAD(‘a(chǎn)bc’,5,‘xx’) – abcxx
LTRIM(s)去掉字符串s開始處的空格
RTRIM(s)去掉字符串s結(jié)尾處的空格
TRIM(s)去掉字符串s開始和結(jié)尾處的空格
TRIM(s1 FROM s)去掉字符串s中開始處和結(jié)尾處的字符串s1SELECT TRIM(’@’ FROM ‘@@abc@@’) – abc
REPEAT(s,n)將字符串s重復(fù)n次SELECT REPEAT(‘a(chǎn)b’,3) – ababab
SPACE(n)返回n個(gè)空格
REPLACE(s,s1,s2)將字符串s2替代字符串s中的字符串s1SELECT REPLACE(‘a(chǎn)bc’,‘a(chǎn)’,‘x’) --xbc
STRCMP(s1,s2)比較字符串s1和s2
SUBSTRING(s,n,len)獲取從字符串s中的第n個(gè)位置開始長(zhǎng)度為len的字符串
MID(s,n,len)同SUBSTRING(s,n,len)
LOCATE(s1,s),POSITION(s1 IN s)從字符串s中獲取s1的開始位置SELECT LOCATE(‘b’, ‘a(chǎn)bc’) – 2
INSTR(s,s1)從字符串s中獲取s1的開始位置SELECT INSTR(‘a(chǎn)bc’,‘b’) – 2
REVERSE(s)將字符串s的順序反過來SELECT REVERSE(‘a(chǎn)bc’) – cba
ELT(n,s1,s2,…)返回第n個(gè)字符串SELECT ELT(2,‘a(chǎn)’,‘b’,‘c’) – b
FIELD(s,s1,s2…)返回第一個(gè)與字符串s匹配的字符串位置SELECT FIELD(‘c’,‘a(chǎn)’,‘b’,‘c’) – 3
FIND_IN_SET(s1,s2)返回在字符串s2中與s1匹配的字符串的位置
-- 字符串函數(shù)SELECT CHAR_LENGTH('我們的征途是星辰和大海')	-- 字符串的長(zhǎng)度SELECT CONCAT('我','愛','貓貓')		-- 拼接字符串SELECT INSERT('我愛編程helloworld',1,2,'超級(jí)熱愛')	-- 查詢,從某個(gè)位置開始替換某個(gè)長(zhǎng)度SELECT LOWER('MaoMao')	-- 小寫字母SELECT UPPER('maomao')	-- 全變大寫SELECT INSTR('maonmao','n')	-- 返回第一次出現(xiàn)的子串的索引SELECT REPLACE('貓貓說堅(jiān)持就能成功','堅(jiān)持','努力')	-- 替換出現(xiàn)的指定字符串SELECT SUBSTR('貓貓說堅(jiān)持就能成功',4,3)	  -- 返回指定的子字符串 (源字符串,截取的位置,截取的長(zhǎng)度)SELECT REVERSE('貓貓說堅(jiān)持就能成功')	-- 反轉(zhuǎn)-- 查詢有田的同學(xué),將田改成豬SELECT REPLACE(studentname,'田','豬') FROM studentWHERE studentname LIKE '%田'
函數(shù)作用例子
CURDATE();CURRENT_DATE()返回當(dāng)前日期SELECT CURDATE()–> 2021-01-09
NOW()返回當(dāng)前日期和時(shí)間SELECT NOW()–> 2021-01-09 10:03:14
LOCALTIME()返回當(dāng)前日期和時(shí)間SELECT LOCALTIME()–> 2021-01-09 10:03:14
UNIX_TIMESTAMP()以UNIX時(shí)間戳的形式返回當(dāng)前時(shí)間SELECT UNIX_TIMESTAMP()->1617977084
-- 時(shí)間和日期函數(shù)(記住)SELECT CURRENT_DATE()	-- 獲取當(dāng)前日期SELECT CURDATE()	-- 獲取當(dāng)前日期SELECT NOW()	-- 獲取當(dāng)前的時(shí)間SELECT LOCALTIME()	-- 本地時(shí)間SELECT YEAR(NOW())SELECT MONTH(NOW())SELECT DAY(NOW())SELECT HOUR(NOW())SELECT MINUTE(NOW())SELECT SECOND(NOW())-- 系統(tǒng)SELECT SYSTEM_USER()SELECT USER()SELECT VERSION()

聚合函數(shù)

函數(shù)名稱描述
COUNT()計(jì)數(shù)
SUM()求和
AVG()平均值
MAX()最大值
MIN()最小值
-- ================ 聚合函數(shù) ============-- 都能夠統(tǒng)計(jì) 表中的數(shù)據(jù) (想查詢一個(gè)表中有多少個(gè)記錄,就是用這個(gè)count())SELECT COUNT(studentname) FROM student;	  -- COUNT(指定列),會(huì)忽略所有的null值SELECT COUNT(borndate) FROM student;	-- 結(jié)果 8 少一個(gè) 因?yàn)槭莕ull
 SELECT COUNT(*) FROM student;	-- Count(*)	不會(huì)忽略所有的null值	本質(zhì) 計(jì)算行數(shù)SELECT COUNT(1) FROM result;	-- Count(1)	不會(huì)忽略所有的null值	本質(zhì) 計(jì)算行數(shù)SELECT SUM(studentresult) AS 總和 FROM resultSELECT AVG(studentresult) AS 平均分 FROM resultSELECT MAX(studentresult) AS 最高分 FROM resultSELECT MIN(studentresult) AS 最低分 FROM result-- 查詢不同課程的平均分,最高分,最低分-- 核心:根據(jù)不同的課程分組SELECT any_value(`subjectname`) AS 科目名,AVG(studentresult) AS 平均分,MAX(studentresult) AS 最高分,MIN(studentresult) AS 最低分FROM result rINNER JOIN `subject` subON r.`subjectno` = sub.`subjectno`GROUP BY r.subjectno	-- 通過什么字段來分組-- 查詢不同課程的平均分,最高分,最低分,平均分大于80SELECT any_value(`subjectname`) AS 科目名,AVG(studentresult) AS 平均分,MAX(studentresult) AS 最高分,MIN(studentresult) AS 最低分FROM result rINNER JOIN `subject` subON r.`subjectno` = sub.`subjectno`GROUP BY r.subjectno	-- 通過什么字段來分組HAVING 平均分>50

數(shù)據(jù)庫(kù)級(jí)別的MD5加密

什么是MD5

主要增強(qiáng)算法復(fù)雜度和不可逆性

MD5 不可逆,具體值的md5是一樣的

MD5 破解網(wǎng)站的原理,背后有一個(gè)字典,MD5加密后的值:MD5加密前的值

-- ====================  測(cè)試MD5 加密  ===================CREATE TABLE `testmd5`(
	`id` INT(4) NOT NULL,
	`name` VARCHAR(20) NOT NULL, 
	`pwd` VARCHAR(50) NOT NULL,
	PRIMARY KEY(`id`))ENGINE=INNODB DEFAULT CHARSET=utf8-- 明文密碼INSERT INTO testmd5 VALUES(1,'zhangsan','123456'),(2,'lisi','123456'),(3,'wangwu','123456')-- 加密UPDATE testmd5 SET pwd=MD5(pwd) WHERE id = 1UPDATE testmd5 SET pwd=MD5(pwd) -- 加密全部的密碼-- 插入的時(shí)候加密INSERT INTO testmd5 VALUES(4,'xiaoming',MD5('123456'))-- 如何校驗(yàn):將用戶傳遞進(jìn)來的密碼,進(jìn)行md5加密,然后比對(duì)加密后的值SELECT  * FROM testmd5 WHERE `name`='xiaoming' AND pwd=MD5('123456')

以上是“MySQL函數(shù)有哪些”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI