MySQL函數(shù)介紹數(shù)據(jù)庫應(yīng)用

MySQL函數(shù)介紹數(shù)據(jù)庫應(yīng)用

mysql函數(shù)

常用函數(shù)

函數(shù) 作用 例子
ABS(x) 返回x的絕對值 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的符號,x是負(fù)數(shù)、0、正數(shù)分別返回-1、0和1 SELECT SIGN(-10) – (-1)
PI() 返回圓周率(3.141593) SELECT PI()– 3.141593
TRUNCATE(x,y) 返回?cái)?shù)值x保留到小數(shù)點(diǎn)后y位的值(與ROUND最大的區(qū)別是不會進(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) 返回自然對數(shù)(以e為底的對數(shù)) SELECT LOG(20.085536923188) – 3
LOG10(x) 返回以10為底的對數(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 絕對值 -- 絕對值SELECT CEILING(9.4) -- 向上取整SELECT FLOOR(9.4)  -- 向下取整SELECT RAND()	-- 返回一個(gè) 0-1 之間的隨機(jī)數(shù)SELECT SIGN(-10)  -- 返回一個(gè)數(shù)的符號	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的長度 SELECT LENGTH(‘你好123’) – 9
CONCAT(s1,s2,…) 將字符串s1,s2等多個(gè)字符串合并為一個(gè)字符串 SELECT CONCAT(‘12’,‘34’) – 1234
INSERT(s1,x,len,s2) 將字符串s2替換s1的x位置開始長度為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的開始處,使字符串長度達(dá)到len SELECT LPAD(‘a(chǎn)bc’,5,‘xx’) – xxabc
RPAD(s1,len,s2) 字符串s2來填充s1的結(jié)尾處,使字符串的長度達(dá)到len SELECT 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é)尾處的字符串s1 SELECT 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中的字符串s1 SELECT REPLACE(‘a(chǎn)bc’,‘a(chǎn)’,‘x’) –xbc
STRCMP(s1,s2) 比較字符串s1和s2
SUBSTRING(s,n,len) 獲取從字符串s中的第n個(gè)位置開始長度為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('我們的征途是星辰和大海')	-- 字符串的長度SELECT CONCAT('我','愛','貓貓')		-- 拼接字符串SELECT INSERT('我愛編程helloworld',1,2,'超級熱愛')	-- 查詢,從某個(gè)位置開始替換某個(gè)長度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)	  -- 返回指定的子字符串 (源字符串,截取的位置,截取的長度)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(指定列),會忽略所有的null值SELECT COUNT(borndate) FROM student;	-- 結(jié)果 8 少一個(gè) 因?yàn)槭莕ull  SELECT COUNT(*) FROM student;	-- Count(*)	不會忽略所有的null值	本質(zhì) 計(jì)算行數(shù)SELECT COUNT(1) FROM result;	-- Count(1)	不會忽略所有的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ù)庫級別的MD5加密

什么是MD5

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

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

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

-- ====================  測試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加密,然后比對加密后的值SELECT  * FROM testmd5 WHERE `name`='xiaoming' AND pwd=MD5('123456')

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

? 版權(quán)聲明
THE END
喜歡就支持一下吧
點(diǎn)贊5 分享