mysql 문자열을 구분자로 구분해서 처리시 관련 함수

· 11년 전 · 4122

문자열을 구분자로 구분해서 처리시 필요해서 만들어 봤습니다. 

 

문자열을 구분자로 읽는 함수 

CREATE DEFINER=`%`@`localhost` FUNCTION `F_SPLIT_STRING`(`nStr` TEXT, `nDelim` VARCHAR(4), `nPos` INT) 

RETURNS TEXT 

LANGUAGE SQL 

NOT DETERMINISTIC 

CONTAINS SQL 

SQL SECURITY DEFINER 

COMMENT '문자열을 구분자로 해당열 가져오기' 

BEGIN 

DECLARE sStr1 TEXT; 

DECLARE sStr2 TEXT; 

 

SET sStr1 = SUBSTRING_INDEX(nStr, nDelim, nPos); 

SET sStr2 = SUBSTRING_INDEX(sStr1, nDelim, -1); 

 

RETURN sStr2; 

END 

 

사용법 : select F_SPLIT_STRING('a,b,c',',',2); 

결과 : b 

----------------------------------------------------------------------------------- 

CREATE DEFINER=`%`@`localhost` FUNCTION `F_ARRAY_LEN`(`nStr` TEXT, `nDelim` VARCHAR(4)) 

RETURNS int(11) 

LANGUAGE SQL 

NOT DETERMINISTIC 

CONTAINS SQL 

SQL SECURITY DEFINER 

COMMENT '특정문자로 배열을 나눌때 배열의 수' 

BEGIN 

DECLARE sLen1 INT; 

DECLARE sLen2 INT; 

DECLARE sLen INT; 

 

set sLen1 = length(nStr); 

set sLen2 = length(replace(nStr,nDelim,'')); 

set sLen = sLen1 - sLen2 + 1; 

 

RETURN sLen; 

END 

사용법 : select F_ARRAY_LEN('a,b,c',','); 

결과 : 3 

|
댓글을 작성하시려면 로그인이 필요합니다.

프로그램

+
제목 글쓴이 날짜 조회
11년 전 조회 2,199
11년 전 조회 2,625
11년 전 조회 2,145
11년 전 조회 6,449
11년 전 조회 4,575
11년 전 조회 6,136
11년 전 조회 1,976
11년 전 조회 2,329
11년 전 조회 2,538
11년 전 조회 2,419
11년 전 조회 2,335
11년 전 조회 1,786
11년 전 조회 4,502
11년 전 조회 4,026
11년 전 조회 3,384
11년 전 조회 2,568
11년 전 조회 2,596
11년 전 조회 4,015
11년 전 조회 1,988
11년 전 조회 2,208
11년 전 조회 3,515
11년 전 조회 4,449
11년 전 조회 2,403
11년 전 조회 1,910
11년 전 조회 2,547
11년 전 조회 1,874
11년 전 조회 2,463
11년 전 조회 1,921
11년 전 조회 2,589
11년 전 조회 2,354
11년 전 조회 3,157
11년 전 조회 4,831
11년 전 조회 4,320
11년 전 조회 4,779
11년 전 조회 2,547
11년 전 조회 2,744
11년 전 조회 3,485
11년 전 조회 2,174
11년 전 조회 2,634
11년 전 조회 4,737
11년 전 조회 3,442
11년 전 조회 1,836
11년 전 조회 2,420
11년 전 조회 2,329
11년 전 조회 1,971
11년 전 조회 4,146
11년 전 조회 2,607
11년 전 조회 2,488
11년 전 조회 1,837
11년 전 조회 4,123
11년 전 조회 4,001
11년 전 조회 1,901
11년 전 조회 4,584
11년 전 조회 2,025
11년 전 조회 1,901
11년 전 조회 2,196
11년 전 조회 1,996
11년 전 조회 1,774
11년 전 조회 2,246
11년 전 조회 2,962
11년 전 조회 2,282
11년 전 조회 1,932
11년 전 조회 1,779
11년 전 조회 3,549
11년 전 조회 3,100
11년 전 조회 3,569
11년 전 조회 2,593
11년 전 조회 3,842
11년 전 조회 4,263
11년 전 조회 5,605
11년 전 조회 6,953
11년 전 조회 3,300
11년 전 조회 2,890
11년 전 조회 2,610
11년 전 조회 2,293
11년 전 조회 2,013
11년 전 조회 2,183
11년 전 조회 2,116
11년 전 조회 2,556
11년 전 조회 3,395
11년 전 조회 2,021
11년 전 조회 2,195
11년 전 조회 2,834
11년 전 조회 2,559
11년 전 조회 2,433
11년 전 조회 2,333
11년 전 조회 2,292
11년 전 조회 4,631
11년 전 조회 2,277
11년 전 조회 2,868
11년 전 조회 3,123
11년 전 조회 2,405
11년 전 조회 2,412
11년 전 조회 2,415
11년 전 조회 1,864
11년 전 조회 2,274
11년 전 조회 2,647
11년 전 조회 2,533
11년 전 조회 1,917
11년 전 조회 2,276