테스트 사이트 - 개발 중인 베타 버전입니다

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

· 11년 전 · 2993

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

 

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

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 

댓글 작성

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

로그인하기

게시글 목록

번호 제목
27182
27176
18634
5442
18632
18629
5435
18627
18626
18623
5409
18621
18617
18615
18614
18608
27162
18607
5405
18606
18605
5401
27152
5397
18603
27144
20667
20666
24485
20651
20632
20620
20607
18602
30749
5396
18601
18599
18596
20590
18589
18587
18586
18585
18584
5387
27106
18583
18580
18579
27120
18574
18570
18566
18562
18558
26490
30733
18554
20572
20541
5377
18553
5373
20534
20531
20527
20525
20519
20513
20507
20503
20496
20490
20483
20471
20464
20447
20419
20405
30729
18549
18544
32084
32083
32082
32081
30728
27097
18537
27092
32080
32079
32078
32077
32076
32075
32074
32073
32072