집 >데이터 베이스 >MySQL 튜토리얼 >MySQL에서 일반적으로 사용되는 문자열 함수를 요약해 보세요!
데이터베이스 함수는 0개 이상의 입력 값을 받고 출력 값을 반환할 수 있는 특정 함수가 포함된 모듈입니다. MySQL은 데이터 처리 및 분석을 위한 다양한 시스템 기능을 제공합니다. 이 기사에서는 일반적으로 사용되는 10가지 문자열 기능과 기타 관련 기능을 소개합니다.
CONCAT()
CONCAT(str1,str2,…)) 함수는 여러 문자열을 연결한 후 문자열을 반환하는 데 사용됩니다. 예:
SELECT CONCAT('MySQL', '字符串', '函数') AS str;
이 함수의 매개 변수가 NULL이면 반환 결과는 NULL입니다. 예:
SELECT CONCAT('MySQL', NULL, '函数') AS str;
문자열 상수의 경우 직접 함께 쓸 수도 있습니다. 예:
SELECT 'MySQL' '字符串' '函数' AS str;
위 방법은 문자열 상수를 연결하는 데에만 사용할 수 있으며 필드 값을 연결하는 데는 사용할 수 없습니다.
SQL 모드 PIPES_AS_CONCAT이 활성화된 경우 Oracle 및 PostgreSQL과 유사하게 MySQL 논리 OR 연산자(||)를 사용하여 문자열을 연결할 수도 있습니다.
CONCAT(str1,str2,…)) 함수 외에도 CONCAT_WS(separator,str1,str2,…)) 함수는 지정된 구분 기호 구분 기호를 사용하여 여러 문자열을 연결하고 구분 기호가 NULL이면 NULL을 반환한다는 의미입니다. . 예:
SELECT CONCAT_WS('-', 'MySQL', NULL, '字符串') AS str1,
LOWER()
LOWER(str) 및 LCASE(str) 함수는 문자열을 소문자로 변환하는 데 사용됩니다. 예:
SELECT LOWER('MySQL字符串函数') AS str1, LCASE('MySQL字符串函数') AS str2;
MySQL 대소문자 변환 함수는 이진 문자열(BINARY, VARBINARY, BLOB)을 지원하지 않습니다. )), 이는 이진이 아닌 문자열로 변환된 후 처리될 수 있습니다. 예:
SELECT LOWER(BINARY 'MySQL字符串函数') AS str1,
UPPER()
UPPER(str) 및 UCASE(str) 함수는 문자열을 대문자 형식으로 변환하는 데 사용됩니다. 예:
SELECT UPPER('MySQL字符串函数') AS str1, UCASE('MySQL字符串函数') AS str2;
LENGTH()
LENGTH(str) 및 OCTET_LENGTH(str) 함수 문자열의 바이트 길이를 반환하는 데 사용됩니다. 예:
SELECT LENGTH('MySQL字符串函数') AS len1, OCTET_LENGTH('MySQL字符串函数') AS len2;
utf8mb4 인코딩에서는 한자 하나가 3바이트를 차지합니다.
또한 CHAR_LENGTH(str) 및 CHARACTER_LENGTH(str) 함수를 사용하여 문자열의 문자 길이, 즉 문자 수를 반환합니다. 예:
SELECT CHAR_LENGTH('MySQL字符串函数') AS len1, CHARACTER_LENGTH('MySQL字符串函数') AS len2;
BIT_LENGTH(str) 함수는 문자열의 비트 길이(비트 수)를 반환하는 데 사용됩니다. 예:
SELECT BIT_LENGTH('MySQL字符串函数') AS len;
A 바이트에는 8비트가 포함됩니다.
SUBSTRING()
SUBSTRING(str,pos), SUBSTRING(str FROM pos), SUBSTRING(str,pos,len) 및 SUBSTRING(str FROM pos FOR len) 함수는 모두 다음에서 시작하는 데이터를 반환하는 데 사용할 수 있습니다. 지정된 위치 pos 하위 문자열, len은 하위 문자열의 길이를 반환함을 의미하고, pos가 0이면 빈 문자열을 반환함을 의미합니다. 예:
SELECT SUBSTRING('MySQL字符串函数', 6) AS str1,
위치 매개변수 pos는 음수가 될 수 있으며, 이 경우 반환된 하위 문자열은 문자열 오른쪽의 pos 문자에서 시작됩니다. 예:
SELECT SUBSTRING('MySQL字符串函数', -2) AS str1,
또한 SUBSTR() 및 MID() 함수는 SUBSTRING() 함수와 동의어이며 위의 4가지 형식도 지원합니다.
LEFT(str,len) 함수는 문자열 str의 왼쪽에 있는 len 문자를 반환하고, RIGHT(str,len) 함수는 문자열 str의 오른쪽에 있는 len 문자를 반환합니다. 예:
SELECT LEFT('MySQL字符串函数',5) AS str1,
SUBSTRING_INDEX(str,delim,count) 함수는 개수 구분 기호 구분 앞에 있는 하위 문자열을 반환합니다. count가 양수이면 왼쪽부터 계산하고 왼쪽의 모든 문자를 반환합니다. count가 음수이면 오른쪽부터 계산하고 오른쪽의 모든 문자를 반환합니다. 예:
SELECT SUBSTRING_INDEX('张三;李四;王五', ';', 2) AS str1,[object Object]
TRIM()
TRIM([remstr FROM] str) 함수는 문자열 str의 양쪽에서 모든 remstr 문자열을 삭제한 후 하위 문자열을 반환하는 데 사용됩니다. Remstr의 기본값은 공백입니다. 예:
SELECT TRIM(' MySQL字符串函数 ') AS str1,
TRIM([{BOTH | LEADING | TRAILING} [remstr] FROM] str) 함수는 기본적으로 문자열 str의 양쪽/왼쪽/오른쪽에 있는 모든 remstr 문자열을 삭제한 후 하위 문자열을 반환하는 데 사용됩니다. , 둘 다 삭제됩니다. 측면 문자열(BOTH), remstr의 기본값은 공백입니다. 예:
SELECT TRIM(LEADING ' ' FROM ' MySQL字符串函数 ') AS str1,
LPAD()/RPAD()
LPAD(str,len,padstr) 함수는 길이가 len이 될 때까지 문자열 str의 왼쪽이 padstr로 채워짐을 의미합니다. ) 함수는 길이가 len이 될 때까지 문자열 str의 오른쪽에 Padstr이 채워짐을 의미합니다. 예:
SELECT LPAD(123, 6, '0') AS str1, LPAD(123, 2, '0') AS str2,
문자열 str의 길이가 len보다 길면 문자열의 오른쪽부터 자르는 것과 같습니다.
또한 REPEAT(str,count) 함수를 사용하여 문자열 str을 count번 복사하여 결과를 반환합니다.
예:
INSTR()
INSTR (str,substr) 이 함수는 문자열 str에서 하위 문자열 substr이 처음 나타나는 인덱스 위치를 반환하는 데 사용됩니다. 하위 문자열이 없으면 0입니다. 반환됩니다. 예:
select INSTR('MySQL字符串函数', '字符串') AS index1,
또한 LOCATE(substr,str) 함수를 사용하여 문자열 str에서 하위 문자열 substr이 처음 나타나는 인덱스 위치를 반환할 수도 있습니다. INSTR(str,substr)과의 유일한 차이점은 다음과 같습니다. 함수는 반대로 매개변수의 순서입니다.
LOCATE(substr,str,pos) 함수는 pos 위치에서 시작하는 문자열 str에서 하위 문자열 substr이 처음 나타나는 인덱스 위치를 반환합니다. 예:
SELECT LOCATE('S','MySQL Server', 5) AS ind;
FIELD (str,str1,str2,str3,…) 함수 문자열 str이 후속 문자열 목록에 나타나는 위치를 반환하거나, 찾을 수 없으면 0을 반환합니다. 예:
SELECT FIELD('李四', '张三', '李四', '王五') AS ind;
FIND_IN_SET (str,strlist) 이 함수는 문자열 strlist에서 문자열 str이 나타나는 위치를 반환합니다. strlist는 쉼표로 구분된 N개의 하위 문자열로 구성됩니다. 예:
SELECT FIND_IN_SET('李四', '张三,李四,王五') AS ind;
REPLACE()
REPLACE (str,from_str,to_str) 함수는 문자열 str의 모든 from_str을 to_str로 바꾸고 대체된 문자열을 반환하는 데 사용됩니다. 예:
SELECT REPLACE('MySQL字符串函数', '字符串', '日期') AS str1,
另外,INSERT (str,pos,len,newstr) 函数用于在字符串 str 的指定位置 pos 之后插入子串 newstr,替换随后的 len 个字符。例如:
SELECT INSERT('MySQL字符串函数', 6, 3, '日期') AS str;
REVERSE()
REVERSE (str) 函数用于将字符串 str 中的字符顺序进行反转。例如:
SELECT REVERSE('上海自来水来自海上')='上海自来水来自海上' AS "回文";
推荐学习:《mysql视频教程》
위 내용은 MySQL에서 일반적으로 사용되는 문자열 함수를 요약해 보세요!의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!