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

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

· 11년 전 · 2987

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

 

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

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 

댓글 작성

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

로그인하기

게시글 목록

번호 제목
28080
7612
7598
7595
19842
28079
19840
7593
28076
7590
28072
28065
19836
7586
28058
7573
31754
7552
28057
30993
28052
7546
7544
7538
7519
30992
19834
7517
7512
7511
19832
19820
7509
24658
7508
7507
19818
30990
7506
7505
7498
7492
28051
7481
30988
19813
19812
7477
7476
7471
7467
19810
7464
19809
7463
7457
30980
7450
28043
7447
7440
28040
7438
7430
7427
7423
7414
7408
7405
7401
7400
19808
7398
7393
7389
19805
7382
7379
7378
7363
7361
7356
19804
7355
7352
19786
7342
7336
7332
19783
7328
7325
7324
28036
19782
7321
26574
7314
7312
19781