Background Image
조회 수 7974 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

1. 개요

 

오라클에서 제공하는 DBMS_RANDOM.STRING() 함수를 CUBRID 에서 어떻게 구현되는지 알아봅니다.

 

DBMS_RANDOM.VALUE() 함수는  CUBRID의 RANDOM() 혹은 DRANDOM() 함수로 구현이 가능합니다.

 

하지만 DBMS_RANDOM.STRING() 함수이용한 임의의 문자열을 생성 하는 것은 아래의 설명을 참고 하시면 됩니다.

 

2. 오라클의 DBMS_RANDOM() 함수 설명

 

숫자와 문자의 랜덤 데이터를 생성 합니다.

 

 a. 임의의 소문자 10자리 생성

 

select
dbms_random.string('l', 10)
from dual;

 

결과

kjrdzqsrcw

 

b. 임의의 대문자 10자리 생성

 

select
dbms_random.string('u', 10)
from dual

 

결과

HRJOWGIZHH

 

c. 임의의 대소문자 10자리 생성

 

select
dbms_random.string('a', 10)
from dual

 

결과

DcXFZOieAe

 

d. 임의의 숫자 및 영문자 10자리 생성

 

select
dbms_random.string('x', 10)
from dual

 

결과

LKGRBM3XDV

 

3. CUBRID에서 오라클의 DBMS_RANDOM 구현

 

CUBRID에서는 RANDOM() 함수와 GROUP_CONCAT() 함수를 결합하여 오라클의 DBMS_RANDOM() 함수 구현이 가능합니다.

 

a. 임의의 소문자 10자리 생성

 

SELECT
GROUP_CONCAT(CHR((RANDOM() % 26) + 97) SEPARATOR '')
FROM db_root
CONNECT BY LEVEL <= 10

 

결과

jrprzvyzhl

 

b. 임의의 대문자 10자리 생성

SELECT
GROUP_CONCAT(CHR((RANDOM() % 26) + 65) SEPARATOR '')
FROM db_root
CONNECT BY LEVEL <= 10

 

결과

CTNEOBSDFZ

 

c. 임의의 대소문자 10자리 생성

SELECT
 GROUP_CONCAT((DECODE(RANDOM() % 2, 0, CHR((RANDOM() % 26) + 97),
         CHR((RANDOM() % 26) + 65))) separator '')
FROM
 db_root
CONNECT BY
 LEVEL <= 10

 

결과

hCsiqCbqaT

 

d. 임의의 숫자 및 영문자 10자리 생성

SELECT
 GROUP_CONCAT((DECODE(RANDOM() % 2, 0, CHR((RANDOM() % 26) + 65),
         CHR((RANDOM() % 10) + 48))) separator '')
FROM
 db_root
CONNECT BY
 LEVEL <= 10

 

결과

0O75SFUXK2


지금까지 오라클의 DBMS_RANDOM.STRING() 함수를 CUBRID 식으로 구현하는 방법을 알아 보았습니다.

 

 

 

 

 

 

 

 

 


List of Articles
번호 분류 제목 글쓴이 날짜 조회 수
34 질의작성 오류데이타검증 - 숫자 이외의 데이타 확인하는 방법 권호일 2013.01.17 21121
33 질의작성 MERGE INTO 사용 예제 ( INSERT, UPDATE문을 1개의 쿼리로 실행 ) 권호일 2015.05.01 21259
32 질의작성 A테이블의 다수의 컬럼을 B테이블로 UPDATE 하는 SQL 김승훈 2015.05.07 7416
31 질의작성 SQL튜닝 - 인덱스 활용 사례 권호일 2015.06.04 12015
30 질의작성 카디시안(한 Row를 여러 Row) 쿼리문 만들기 1 엄기호 2015.06.30 10927
29 질의작성 CUBRID dummy data생성-간단편 주현 2015.07.01 7860
28 질의작성 INSERT수행 시, 현재날짜,현재시각으로 자동 입력하는 방법 주현 2015.07.08 25218
27 질의작성 전체 테이블 UPDATE시 SELECT, UPDATE를 통한 INDEX SCAN방식으로 테이블 X_LOCK을 방지하자! file 이경오 2015.08.13 13802
26 질의작성 테이블 용량 산정 쿼리 성진 2015.12.08 7398
» 질의작성 오라클의 DBMS_RANDOM.STRING() 함수를 CUBRID 식으로 구현하는 방법 이경오 2015.12.08 7974
24 질의작성 일정 범위 임의의 정수 생성 방법(random 함수 응용) 손승일 2015.12.22 6472
23 질의작성 Cubrid는 어떤 쿼리를 동일한 쿼리로 판단할까? 이상신 2015.12.30 4011
22 질의작성 ORACLE TRIGGER를 CUBRID TRIGGER로 변환하기 김창휘 2015.12.31 6461
21 질의작성 각 테이블 PK 유무 확인 쿼리문 엄기호 2016.01.01 9021
20 질의작성 FOR UPDATE 정만영 2016.01.27 5990
19 질의작성 테이블 컬럼 변경 및 추가 정만영 2016.02.29 21863
18 질의작성 테이블 리스트 취합 SQL 김창휘 2016.03.19 5522
17 질의작성 Oracle UTL_ENCODE.TEXT_ENCODE를 CUBRID로 변환하기 김창휘 2016.03.21 4647
16 질의작성 스키마 및 인덱스 선언에 따른 최대 용량 산정을 위한 ROW SIZE 확인 성진 2016.03.21 4179
15 질의작성 ORACLE 테이블 및 컬럼 COMMENT 일광등록 스크립트 1 김창휘 2016.04.04 9337
Board Pagination Prev 1 2 3 4 Next
/ 4

Contact Cubrid

대표전화 070-4077-2110 / 기술문의 070-4077-2113 / 영업문의 070-4077-2112 / Email. contact_at_cubrid.com
Contact Sales