일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | ||
6 | 7 | 8 | 9 | 10 | 11 | 12 |
13 | 14 | 15 | 16 | 17 | 18 | 19 |
20 | 21 | 22 | 23 | 24 | 25 | 26 |
27 | 28 | 29 | 30 |
- java
- rabbitmq
- 자동배포
- mom
- sqlserver
- Javascript
- 보안
- poi
- docker
- JQuery
- apache.poi
- DevOps
- mssql
- 자바8
- 제이쿼리그리드
- ORM
- 스트림
- JPA
- stream api
- jqGrid
- 대용량 업로드
- 엑셀 업로드
- ci/cd
- 자동빌드
- MessageQueue
- Stream
- spring
- Jenkins
- QueryDSL
- 그리드
- Today
- Total
목록oracle (3)
개발 메모장

보통 쿼리를 작성할 때 특정 데이터를 뽑아내려 하면 서브쿼리로 작성하는 경우가 많습니다.하지만 서브쿼리를 사용하게 되면 가독성이 떨어지고 유지보수가 어려워질 수 있으며 중복된 서브쿼리를 계속해서 작성할 경우 성능 또한 떨어지게 됩니다.이때 사용하기 좋은 with문에 대해 알아보도록 하겠습니다.#. WITH 문이란? CTE(Common Table Expression, 공용 테이블 표현식)라고도 하며, WITH 문은 단일 SQL 범위 내에서 참조할 수 있는 임시 결과 집합을 정의할 수 있는 SQL 기능입니다.1. 사용 범위- WITH문의 범위는 WITH 뒤에 나오는 SQL 문으로 제한되기에 WITH문을 다시 정의하지 않는 한 후속 쿼리에서 WITH문을 참조할 수 없으므로 가장 먼저 정의..

#. 다량의 데이터가 있는 테이블 또는 여러 테이블이 조인 돼있는 쿼리를 실행하면 속도가 느린 경우가 자주 발생하게 됩니다. #. 쿼리가 실행될 때 최대한의 부담을 덜어줘야 DBMS도 최상의 성능을 발휘하여 우리가 원하는 값을 보여줄 것입니다. #. 어떻게 해야 시스템이 부하가 걸리지 않고 빠른 응답을 할지에 대해 파악해보려 합니다. 1. Index 생성 - Where, Join On, Order by 절에서 자주 사용되고 수정하지 않는 컬럼을 파악하여 생성합니다. - Index 생성에 사용한 컬럼은 되도록 Where 조건에 모두 사용하는 것이 좋습니다. - 조건절에 >=, Example- employees 테이블에 employee_id, department_..

#. DB를 다루다 보면 있어선 안 되지만 실수하는 경우가 발생할 수 있습니다. #. TimeStamp를 이용하여 원복 해보도록 하겠습니다.Step 0. 현재 테이블에는 아래와 같은 데이터가 있고 이후 데이터를 삭제하고 이후 데이터를 추가해 테스트 환경을 만듦 Step 1-1. TimpStamp를 이용하여 조회(현재 시간 기준 - 지정한 이전 시간의 데이터 조회) 원하는 만큼의 시간과 SECOND / MINUTE / HOUR / DAY를 조합하여 사용Example - INTERVAL '30' MINUTE를 이용해 30분 전의 데이터를 조회 SELECT * FROM 테이블 AS OF TIMESTAMP(SYSTIMESTAMP - INTERVAL '30' MINUTE) St..