< 집합 쿼리 >
a={1,3,5,7} b={1,2,3,4}
union : 합집합
a union b = {1,2,3,4,5,7}
union all : 공통원소 두번씩 다 포함한 합집합
a union all b = {1,1,2,3,3,4,5,7}
intersect : 교집합
a intersect b = {1,3}
minus : 차집합
a minus b = {2,5,7}
< 문자열 >
1 . CONCAT( column1|expressionŋ ,column2|expressionŌ )
CONCAT('Good','String') --> GoodString : ||와 같은 역할을 한다.
2 . SUBSTR(column|expression!, m [,n]) : m값이 음수면 문자값의 끝부터 (글자기준 )
SUBSTR('String',1,3) --> Str : 1번째부터 3개의 문자를 리턴한다.
3. SUBSTRB(column|expression!, m [,n]) : m값이 음수면 문자값의 끝부터 (바이트기준 )
SUBSTRB('String',1,3) --> Str : 1번째부터 3개의 문자를 리턴한다
4. INITCAP( column|expression! )
INITCAP('string') --> String : 첫글자만 대문자, 나머지글자는 소문자로 변환
5. UPPER( column|expression! )
UPPER('String') --> STRING : 대문자로 변환
6. LOWER( column|expression! )
LOWER('String') --> string : 소문자로 변환
7. LPAD( column|expression!,n,'string' ) : n 은 전체 길이와 채울문자(숫자가능)
LPAD('String',10,'*') --> ****String
8. RPAD('String',10,'*') --> String****
9. LENGTH( column|expression! )
LENGTH('String') --> 6 : 문자열의 길이를 리턴한다.
10. REPLACE(column | 0 , 'r') L01102 => Lr11r2
11. INSTR( column|expression! )
INSTR('String','r') --> 3 : 문자열에 'r'이 몇번째 위치인지를 (숫자)리턴
12. LTRIM(' String') --> 'String' : 문자열의 왼쪽 공백을 버린다.
13. RTRIM('String ') --> 'String' : 문자령의 오른쪽 공백을 버린다.
* TRIM(leading/tailing/both, trim_character FROM trim_source )
TRIM( 'S' FROM 'SSMITH') --> MITH
< 숫자 >
1. ROUND(45.926, 2) --> 45.93 : 소수점 두자리수까지 보여주면서 반올림한다.
SELECT ROUND(45.923,2), ROUND(45.923,0), ROUND(45.923,-1) FROM DUAL
==> 45.92 46 50
2. TRUNC(45.926, 2) --> 45.92 : 소수점 두자리까지만 보여주고 나머지는 버린다.
SELECT TRUNC(45.923,2), TRUNC(45.923), TRUNC(45.923,-1) FROM DUAL
==> 45.92 45(n이 생략된면 일의 자리까지 남기고 버린다.) 40
3. MOD(1600,300) --> 100 : 1600을 300으로 나누고 나머지를 리턴한다.
< Date >
* SYSTEM 날짜를 갖고 오는 방법.
SELECT sysdate FROM dual
date + number : date에 number만큼 후의 날자를 보여준다.
date - number : date에 number만큼 전의 날자를 보여준다.
date1 - date2 : date1에서 date2 까지의 총 일수를 보여준다.( date1+date2는 X )
date1 + 숫자/24 : date1에서 시간을 더해 날짜를 보여준다.
MONTHS_BETWEEN('01-SEP-95','11-JAN-94') --> 19.6774194
; 두날짜 사이의 달수를 보여준다.
ADD_MONTHS('11-JAN-94', 6) --> 11-JUL-94
; 날짜에 6개월을 더한 날자를 보여준다.
NEXT_DAY('01-SEP-95','FRIDAY') --> '08-SEP-95'
; 해당일 다음에 오는 FRIDAY의 일자를 보여준다.
('SUNDAY'는 1, 'MONDAY'는 2...이런식으로 숫자를 써줘도 된다.)
LAST_DAY('01-SEP-95') --> '30-SEP-95'
; 해당월의 마지막날자를 보여준다.
ROUND('25-JUL-95','MONTH')--> 01-AUG-95
ROUND('25-JUL-95','YEAR')--> 01-JAN-96
TRUNC('25-JUL-95','MONTH') --> 01-JUL-95
TRUNC('25-JUL-95','YEAR') --> 01-JAN-95
< Conversion Functions >
nlsparams : 십진수, 그룹구분자, 지역 통화 기호, 국제 통화 기호
TO_CHAR(date,['format'],[nlsparams]) : date를 format에 맞게 문자열로 변환한다.
- Date Format Elements
YYYY --> 1999 (년출력) , YEAR --> nineteen ninety-nine (년출력)
MM --> 12 (월출력) , MONTH --> DECEMBER (월출력), MON --> DEC
D --> 요일을 숫자로 리턴한다.(일요일은 1, 월요일은 2...)
DD --> 07 (달의 일출력)
DDD --> 200 (연의 일출력)그 해의 총 몇 일째인가를 리턴한다.
DAY --> MONDAY (요일출력) DY-->MON
CC --> 20 (몇 세기인지를 보여준다.)
WW --> 그 해의 몇 번째 주인가를 리턴한다.
W --> 그 달의 몇 번째 주인가를 리턴한다.
HH or HH12 or HH24 / MI(0-59분) / SS(0-59초)
* 문자열은 " " 묶어 추가한다 DD " of " MONTH --> 12 of DECEMBER
* 숫자 접미어는 숫자를 문자로 표기. TH(4->4TH)/ SP(4->FOUR)/ SPTH or THSP(4->FOURTH)
TO_CHAR(number,'format',[nlsparams]) : number를 format에 맞게 문자열로 변환한다.
- Number Format Elements
9 : 999,999 --> 1,234 $: 부동 달러 기호 $99999 -> $1234
0 : 099999 --> 001234 99.999EEEE -> 1.234E+03 B: 0값을 공백으로
L : L99,999 --> FF1,234 (NLS_CURRENCY에 설정되어있는 값이 L로 보여진다.)
TO_NUMBER(char,['format'],[nlsparams]) : 숫자형태의 문자열을 숫자로 변한한다.
TO_DATE(char,['format'],[nlsparams]):날자형태의 문자열을 format에 맞게 날자형식으로 변환 한다.
< NVL Funcion >
: 값이 null일 때 설정값을 보여준다.
NVL(number_column, 0) : null일 때 0을 보여준다.
NVL(date_column, '01-JAN-95') : null일 때 '01-JAN-95'를 보여준다.
NVL(character_column, 'Empty') : null일 때 'Empty'를 보여준다.
* column Type과 표현식의 type이 반드시 일치해야 한다.
< DECODE Function >
: CASE or IF-THEN-ELSE 형식과 비슷하다.
DECODE(col/expression!, search1, result1 [,search2,result2,…] [,default])
ABS (n) n의 절대값
CEIL (n) n보다 크거나 같은 최소정수
COS (n) n의 cosine값
COSH (n) n의 hyperbolic cosine값
EXP (n) e(2.71828183...)의 n 지수승
FLOOR (n) n보다 작거나 같은 최대정수
LN (n) n(>0)의 자연로그
LOG (m,n) m의 n로그
MOD (m,n) m을 n으로 나눈 나머지
POWER (m,n) m의 n 지수승
ROUND (n[,m]) 소수점 m자리에서 반올림 ; m이 생략된 경우 default 값 0
SIGN (n) n < 0 이면 -1, n = 0 이면 0, n > 0 이면 1
SIN (n) n 의 sine값
SINH (n) n의 hyperbolic sine값
SQRT (n) n 의 root 근
TAN (n) n의 tangent
TANH (n) n의 hyperbolic tangent값
TRUNC (n[,m]) 소수점 m자리에서 절삭 ; m이 생략된 경우 default 값 0
nvl(col명, 값) column값이 null값일 때, 값을 가진다.