무료 학습 권장 사항: mysql 비디오 튜토리얼
이 문서에서는 모든 일반적인 MySQL 메서드를 포함하여 MySQL의 함수 메서드를 설명합니다. 다음은 이 글의 디렉터리 구조입니다. 오른쪽에 있는 디렉터리를 클릭하여 필요에 따라 검색할 수 있습니다.
(1) 숫자 함수
1. ABS(x)는 x
SELECT ABS(-1); ---- 返回1
2의 절대값을 반환하며, 표현식은 필드입니다
SELECT AVG(age) FROM student;
3. CEIL(x)/CEILING(x)는 x
SELECT CEIL(1.5); SELECT CEILING(1.5); ---- 返回2
4보다 크거나 같은 가장 작은 정수를 반환합니다. x
SELECT FLOOR(1.5); ---- 返回1
5. EXP( x)
SELECT EXP(3); ---- 计算 e 的三次方,返回20.085536923188
8의 최소값의 거듭제곱을 반환합니다. LN은 숫자
SELECT GREATEST(3, 12, 34, 8, 25); ---- 返回以下数字列表中的最大值34
9의 자연 로그를 반환합니다. LOG(x)는 반환합니다. 자연 로그(밑이 e인 로그)
SELECT LEAST(3, 12, 34, 8, 25); ---- 返回以下数字列表中的最小值3
10, MAX(수식)는 필드 표현식
SELECT LN(2); ---- 返回 2 的自然对数:0.6931471805599453
11의 최대값을 반환합니다. MIN(표현식)은 필드 표현식
SELECT LOG(20.085536923188); ---- 返回 3
12. POW(x,y)/POWER(x,y)는 x의 y
SELECT MAX(age) AS maxAge FROM Student; ---- age最大值
13을 반환합니다. RAND()는 0에서 1
SELECT MIN(age) AS minAge FROM Student; ---- age最小值
14 사이의 임의의 숫자를 반환합니다. (x)는 x
SELECT POW(2,3); SELECT POWER(2,3); ---- 返回2 的 3 次方:8
15에 가장 가까운 정수를 반환합니다. SIGN(x)은 x의 부호를 반환하고, x는 음수, 0, 양수는 각각 -1, 0, 1을 반환합니다
SELECT RAND(); ---- 返回 0 到 1 的随机数,若()里面有数字,RAND(x),x相同时,返回值相同
16. SQRT(x)는 x
SELECT ROUND(1.23456); ---- 返回 1
17의 제곱근을 반환합니다. SUM(표현식)은 지정된 필드 Sum의 값을 반환합니다. TRUNCATE(x,y)는 유지된 값을 반환합니다. 소수점 이하 y 자리까지 (ROUND와 가장 큰 차이점은 반올림되지 않는다는 점)
SELECT SIGN(-10); ---- 返回 -1
(2) 문자열 함수
1. 문자열 s
의 첫 번째 문자의 ASCII 코드를 반환합니다.SELECT SQRT(25); ---- 返回5
2.LENGTH/CHAR_LENGTH(s)/CHARACTER_LENGTH(s)는 문자열 s
SELECT SUM(age) AS totalAage FROM Student; ---- 返回age的总和
3의 문자 수를 반환합니다. CONCAT( s1,s2...sn) 문자열 s1, s2 및 기타 문자열이 결합됩니다. 하나의 문자열
SELECT TRUNCATE(1.23456,3); ---- 返回1.234
4. FIND_IN_SET(s1,s2)는 문자열 s2
SELECT ASCII('AB'); ---- 返回A的ASCII码值:65
5에서 s1과 일치하는 문자열의 위치를 반환합니다. FORMAT(x,n) 함수는 숫자 INSERT(s1, x,len,s2) 문자열 s2는 s1의 x 위치를 길이가 len
SELECT LENGTH('1234'); ---- 返回4
7인 문자열로 대체합니다. LOCATE(s1,s)는 문자열 s
SELECT CONCAT('hel','llo'); ---- 返回hello
8에서 s1의 시작 위치를 가져옵니다. LCASE(s)/LOWER(s)는 문자열 s의 모든 문자를 소문자로 바꿉니다
SELECT FIND_IN_SET("c", "a,b,c,d,e"); ---- 返回3
9, UCASE(s)/UPPER(s)는 문자열 s의 모든 문자를 대문자로 바꿉니다
SELECT FORMAT(250500.5634, 2); ---- 返回250,500.56
10. TRIM(s)은 문자열 s
SELECT INSERT("google.com", 1, 6, "runnob"); ---- 返回runoob.com
11의 시작과 끝에서 공백을 제거합니다. LTRIM(s)은 문자열 s
SELECT LOCATE('st','myteststring'); ---- 返回5
12. s) 문자열 s
SELECT LOWER('RUNOOB'); ---- 返回runoob
13의 끝에서 공백을 제거합니다. SUBSTR(s, start, length)는 문자열 s
SELECT UCASE('runoob'); ---- 返回RUNOOB
14의 시작 위치에서 length의 하위 문자열을 차단합니다. , start, length)는 문자열 s
SELECT TRIM(' RUNOOB '); ---- 返回RUNOOB
15의 시작 위치에서 length의 하위 문자열을 가로챕니다. POSITION(s1 IN s)은 문자열 s
SELECT LTRIM(' RUNOOB '); ---- 返回 ’RUNOOB ‘
16에서 s1의 시작 위치를 가져옵니다. n) 문자열 s를 n번 반복합니다
SELECT RTRIM(' RUNOOB '); ---- 返回 ’ RUNOOB‘
17. REVERSE(s)는 문자열 s
SELECT SUBSTR("RUNOOB", 2, 3) AS ExtractString; ---- 从字符串 RUNOOB 中的第 2 个位置截取 3个 字符,返回UNO
18의 순서를 바꿉니다. STRCMP(s1,s2)는 문자열 s1과 s2를 비교합니다. 같음, 0 반환, s1>s2이면 1 반환, s1
SELECT SUBSTR/SUBSTRING("RUNOOB", 2, 3); ---- 从字符串 RUNOOB 中的第 2 个位置截取 3个 字符,返回UNO
반환 (3) 날짜 함수
1, CURDATE()/CURRENT_DATE() 현재 날짜를 반환
SELECT POSITION('b' in 'abc'); ---- 返回2
2, CURRENT_TIME()/CURTIME() 현재 시간 반환
SELECT REPEAT('runoob',3); ---- 返回runoobrunoobrunoob
3, CURRENT_TIMESTAMP() 현재 날짜와 시간 반환
SELECT REVERSE('abc'); ---- 返回cba
4, ADDDATE(d,n) 계산 시작 날짜 d 플러스 n일의 날짜
SELECT STRCMP("runoob", "runoob"); ---- 返回0
5. ADDTIME(t,n) 시간 t + n초의 시간
SELECT CURDATE(); SELECT CURRENT_DATE(); ---- 返回2019-02-19
6. DATE()는 날짜 또는 날짜/시간 표현식 값
SELECT CURRENT_TIME(); ---- 返回11:40:45
7에서 날짜를 추출합니다. (d) 날짜 값 d
의 날짜 부분을 반환합니다.SELECT DAY("2017-06-15"); ---- 返回15
8、DATEDIFF(d1,d2)计算日期 d1->d2 之间相隔的天数
SELECT DATEDIFF('2001-01-01','2001-02-02'); ---- 返回-32
9、DATE_FORMAT按表达式 f的要求显示日期 d
SELECT DATE_FORMAT('2011.11.11 11:11:11','%Y-%m-%d %r'); ---- 返回2011-11-11 11:11:11 AM
10、DAYNAME(d)返回日期 d 是星期几,如 Monday,Tuesday
SELECT DAYNAME('2011-11-11 11:11:11'); ---- 返回Friday
11、DAYOFMONTH(d)计算日期 d 是本月的第几天
SELECT DAYOFMONTH('2011-11-11 11:11:11'); ---- 返回11
12、DAYOFWEEK(d)日期 d 今天是星期几,1 星期日,2 星期一,以此类推
SELECT DAYOFWEEK('2011-11-11 11:11:11'); ---- 返回6
13、DAYOFYEAR(d)计算日期 d 是本年的第几天
SELECT DAYOFYEAR('2011-11-11 11:11:11'); ---- 返回315
14、EXTRACT(type FROM d)从日期 d 中获取指定的值,type 指定返回的值
type可取值为:
MICROSECOND
SECOND
MINUTE
HOUR
DAY
WEEK
MONTH
QUARTER
YEAR
SECOND_MICROSECOND
MINUTE_MICROSECOND
MINUTE_SECOND
HOUR_MICROSECOND
HOUR_SECOND
HOUR_MINUTE
DAY_MICROSECOND
DAY_SECOND
DAY_MINUTE
DAY_HOUR
YEAR_MONTH
SELECT EXTRACT(MINUTE FROM '2011-12-13 14:15:16'); ---- 返回15
15、DAYOFWEEK(d)日期 d 今天是星期几,1 星期日,2 星期一,以此类推
SELECT DAYOFWEEK('2011-11-11 11:11:11'); ---- 返回6
16、UNIX_TIMESTAMP()得到时间戳
SELECT UNIX_TIMESTAMP('2019-2-19'); SELECT UNIX_TIMESTAMP(expression); ---- 返回1550505600
17、FROM_UNIXTIME()时间戳转日期
SELECT FROM_UNIXTIME(1550505600); ---- 返回2019-02-19 00:00:00 SELECT FROM_UNIXTIME(1550505600, '%Y-%m-%d'); ---- 返回2019-02-19
(四)MySQL高级函数
1、IF(expr,v1,v2)如果表达式 expr 成立,返回结果 v1;否则,返回结果 v2
SELECT IF(1>0,'yes','no'); ---- 返回yes
2、CONV(x,f1,f2)返回 f1 进制数变成 f2 进制数
SELECT CONV(13,10,2); ---- 返回1101
3、CURRENT_USER()/SESSION_USER()/SYSTEM_USER()/USER()返回当前用户
4、DATABASE()返回当前数据库名
5、VERSION()返回数据库的版本号
有不正确的地方,欢迎前来指正!
相关免费学习推荐:mysql数据库(视频)
위 내용은 MySQL에서 일반적으로 사용되는 기능 요약의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!