All Story

    반응형
    이미지21

    [ Oracle ] 오라클 함수

    현 포스팅은 세세하게 함수에 대해 알아보기 보다 간단 요약해 참고하기위한 포스팅임. 함수란? "어떤 입력값을 받아서 정해진 루틴에 의해 작업을 하고 결과값을 만들어서 출력해주는 것" 함수는 여러 건의 데이터를 한 번에 하나씩만 처리하는 단일행 함수​와 여러 건의 데이터를 동시에 입력받아 결과값 한 건을 만들어주는 복수행 함수가 있다. 단일행 함수는 숫자 함수, 문자처리 함수, 날짜 함수, 형변환 함수 등이 있다. 단일행 함수에 대해 먼저 살펴보자. 1. 단일행 함수 - 숫자 함수 ABS 절대 값을 구하는 함수 ( 방향은 없고 크기만 있는 것 ) //return 10 SELECT ABS(-10) FROM DUAL; //return 15 SELECT ABS(0015) FROM DUAL; ​ FLOOR 소수점..

    이미지21

    [ Database ] 인덱스 Index

    인덱스란? 그냥 단순히 생각하면 검색을 빠르게 하기 위한 자료구조이다. 보통 기본키가 자동으로 인덱스 설정되는데 데이터가 반드시 정렬이 되있어야 한다. 인덱스의 장점 검색할 때 인덱스를 기준으로 바로 찾아나가기 때문에 검색 속도가 빨라진다. 시스템에 걸리는 부하를 줄여 시스템 전체 성능을 향상시킨다. 인덱스의 단점 인덱스를 생성하는데 시간과 공간이 소요된다. 데이터 변경작업(INSERT, UPDATE, DELETE)이 자주 일어날 경우에는 오히려 성능이 저하된다. 그럼 인덱스 명령어들은 무엇이 있을까? 단일 인덱스 생성 CREATE INDEX 인덱스명 ON 테이블명 (컬럼명) 복합 인덱스 생성 CREATE INDEX 인덱스명 ON 테이블명 (컬럼명1, 컬럼명2...) 중복 불가능한 인덱스 생성 CREAT..

    이미지21

    [ Oracle ] SQL 서브쿼리 SELECT, FROM, WHERE

    서브쿼리란? - 하나의 쿼리 문장 내에 포함된 또 하나의 쿼리 문장. - 비교연산자의 오른쪽에 기술해야 하고 반드시 괄호 안에 넣어야 함. - 메인 쿼리가 실행되기 이전에 한 번만 실행됨. SQL의 기본 문법이자 가장 자주쓰이는 SELECT, WHERE, FROM. ​ 서브쿼리를 각각의 어느 위치에서 사용하냐에 따라 나누어진다. ​ 각각의 종류에 따라 살펴보자. SELECT 절 서브쿼리 ( 스칼라 서브쿼리 ) 스칼라 서브쿼리 ( Scalar Subqueries )​ 라고 불리며 SELECT 절 안에 서브쿼리가 들어있다. ​ 이 때, 서브쿼리의 결과는 반드시 단일 행이나 SUM, COUNT 등의 집계 함수를 거친 단일 값으로 리턴되어야 한다. ​ 이유는 서브쿼리를 끝마친 값하나를 메인쿼리에서 SELECT ..

    이미지21

    [ Oracle ] 오라클 LPAD 와 RPAD

    개발을 하다 보면 문자열을 지정된 크기에 맞게 채워야 할 때가 있다. ​ 전화번호를 11자리로 하는데 11자리 미만일경우 0으로 채워라는 경우처럼 말이다. ​ 특정문자열을 지정한 자릿수만큼 내가 지정한 문자로 채우고자 할 때 쓰는 함수가 바로 LPAD 와 RPAD 함수이다. ​ PAD의 영어사전적 의미로는 '덧대다'의 뜻인데 개발에서는 이를 '덧붙이다'나 '채우다'라는 의미로 사용되고 있다. ​ 즉, LEFT PAD ( LPAD ) 는 왼쪽으로부터 채우기, RIGHT PAD ( RPAD ) 는 오른쪽으로부터 채우기인 셈이다. ​ 먼저 문법을 살펴보자. ​LPAD ( x, n, y ) RPAD ( x, n, y ) 여기서 x 는 LPAD 나 RPAD 를 적용시키고자 하는 문자열이 들어간다. ​ n 은 자릿..

    이미지21

    [ Oracle ] 오라클 중복데이터 처리, 중복데이터 한번만

    중복 데이터를 처리하는 방법은 다양하다. ​ 중복 데이터를 처리하는 방법에는 어떤것들이 있는지 살펴보자. ​ 만약 아래와 같은 정렬되지 않은 의류 테이블이 존재한다고 가정하자. ​ [ 의류 ] 테이블 위 데이터를 보면 No2 ROW 와 No5 ROW 가 중복되는 데이터임을 알 수 있다. ​ 중복데이터를 제거하고 싶다면 흔히 알고 있는 DISTINCT를 사용하면 된다. SELECT DISTINCT 분류명, 색상명, 가격, 상품번호 FROM 의류 ; 그럼 아래와 같은 결과가 나올것이다. 이처럼 DISTINCT는 데이터가 모두 동일한 ROW가 존재할경우 이를 제거해준다. ​ 그렇다면 중복데이터를 제거하는 것이 아닌 공백이나 널로 처리해 해당데이터가 하나만 보이게하려면 어떻게 해야할까? 필자의 경우 서브쿼리를 ..