[postgreSQL] ORACLE쿼리에서 postgreSQL쿼리 변환

회사에서 SM 운영 업무를 줄곧 해오면서 DB 사용에 있어 오라클 DB를 벗어날 일이 크게 없었다.
안정성이 최우선으로 생각되는 SM업무에서 라이센스 비용을 들이더라도 상용 DB를 쓰는것이 어쩌면 맞을 듯 싶다. 그 책임을 개발자가 갖고 가기엔 무리가 있어 보인다.
최근 대외 사업을 하며 다양한 오픈소스DB들을 검토하며 각 성능 및 POC까지 진행하여 어느정도
사업에 맞는 오픈소스 DB를 선정하였고 이제 어느 정도 정착이 되어가는 듯 보인다.
물론 프로시져 지원 안되는 거라든지 형 변환에 더 까다롭다던지 DB LINK 시 속도가 떨어진다든지 이슈가 없는 것은 아니지만 PostgreSQL 쿼리로 개발하며 느낀점은 Oracle쿼리와 70% 정도 비슷하고 Oracle에서 쓸수 있는 함수들도 PostgreSQL 에서 다른 함수들로 제공을 하고 있기에 개발하면서 쿼리때문에 생산성이 떨어진다던지 시간을 크게 소비한 경우는 아직까진 없었다는 점이다. 물론 성능적인 부분에서는 개발과정에선 잘 들어나지 않고 운영하면서 데이터가 쌓이면서 나오기 때문에 아직 섣불리 PostgreSQL이 좋다라고 단정지을 순 없을 듯 하다. Oracle 쿼리 개발을 하다 이번에 PostgreSQL 쿼리를 개발하면서 알게 된 내용들을 하나씩 정리하고 넘어가 보려한다.

1. DUAL 
오라클에서 사용하는 DUAL 은 제외하고 사용한다.
SELECT 1 FROM DUAL 과 같이 DUAL 을 사용할 수 없다.

EX> SELECT 1 로만 작성하면 된다.

2. SYSDATE
now() 함수를 사용한다.
EX> SELECT to_char(now(), 'YYYY-MM-DD')

3. NVL
COALESCE 함수를 사용한다
SELECT COALESCE(USER_ID, 0) FROM USER_INFO

4. SEQUENCE(시퀀스)
오라클 시퀀스 문법은 시퀀스명.NEXTVAL 
PostgreSQL 에서는 
NEXTVAL('시퀀스명') 으로 사용한다.

5. ROWNUM
오라클(Oracle)에서 사용하는 ROWNUM 을 PostgreSQL에서 사용하는 방법
    ▶ WHERE 절에서 사용

         SELECT USER_ID FROM USER_INFO LIMIT 3
    ▶ SELECT 절에서 사용
         SELECT (ROW_NUMBER() OVER()) AS ROWNUM , USER_ID FROM USER_INFO
         ==> ROW_NUMBER() OVER() 함수를 통하여 ROWNUM을 생성한다.

6. DECODE
PostgreSQL에서는 DECODE 함수를 제공하지 않는다.
CASE문으로 변경한다.

CASE WHEN REG_TYPE = '003' THEN ITEM_TYPE ='QM' ELSE ITEM_TYPE ='GN' END

7. 데이터 형변환
컬럼 혹은 값에 ::[변환할 데이터타입]  붙여서 변환
EX>  SELECT '1'::int


8. Outer Join
▶ 오라클

SELECT D.DNAME, E.EMP_NO FROM DEPT D, EMP E
WHERE  D.DEPT_NO = E.DEPT_NO(+)

▶ PostgreSQL

SELECT D.DNAME, E.EMP_NO
FROM DEPT D
LEFT OUTER JOIN EMP E ON D.DEPT_NO = E.DEPT_NO;

PostgreSQL에서는 ANSI SQL 표준을 사용(오라클에서도 정상 동작)
RIGHT OUTER JOIN, FULL OUTER JOIN도 사용 가능.

경축! 아무것도 안하여 에스천사게임즈가 새로운 모습으로 재오픈 하였습니다.
어린이용이며, 설치가 필요없는 브라우저 게임입니다.
https://s1004games.com

오라클에서 정말 자주 사용 하는 함수 몇개를 정리해 보았다. PostgreSQL 쿼리를 작성하더라도
크게 어렵지 않게 오라클에서 사용하던 함수 기능과 동일한 결과들을 구현할 수 있다. 오라클 쿼리를 작성하기 위해 Toad(토드)나 SQL Developer나 Orange 같은 툴을 사용하듯 PostgreSQL을 작성하기 위해 HeidiSQL 툴을 시용하여 개발을 하는데 잔 버그가 좀 있고 가끔 응답없음으로 프로그램을 닫어야 하는 상황이 오는 문제를 제외하면 그럭저럭 쓸만한 것 같다.

다음 포스팅에는 오라클 쿼리 작성시 자주 사용되는 MERGE 구문과 START WITH CONNECT BY 계층형 쿼리를 어떻게 구현하고 데이터 PIVOT(행을 열로 전환하는) 등등을 PostgreSQL 작성시 어떻게 구현하는지  정리해 보고자 한다.

[출처] https://blog.naver.com/wiseyoun07/221135110180

 

본 웹사이트는 광고를 포함하고 있습니다.
광고 클릭에서 발생하는 수익금은 모두 웹사이트 서버의 유지 및 관리, 그리고 기술 콘텐츠 향상을 위해 쓰여집니다.
번호 제목 글쓴이 날짜 조회 수
공지 오라클 기본 샘플 데이터베이스 졸리운_곰 2014.01.02 25085
공지 [SQL컨셉] 서적 "SQL컨셉"의 샘플 데이타 베이스 SAMPLE DATABASE of ORACLE 가을의 곰을... 2013.02.10 24564
공지 [G_SQL] Sample Database 가을의 곰을... 2012.05.20 25943
1025 [postgreSQL] PostgreSQL 계층형 쿼리 구현 방법 졸리운_곰 2023.01.29 35
» [postgreSQL] ORACLE쿼리에서 postgreSQL쿼리 변환 졸리운_곰 2023.01.29 26
1023 [postgreSQL] [PostgreSQL] stored function(stored procedures) 사용하기 졸리운_곰 2023.01.23 30
1022 [SQL] CRUD 기본 사용법 file 졸리운_곰 2023.01.23 30
1021 [postgreSQL] [Docker] Docker에 PostgreSQL 설치하기 file 졸리운_곰 2023.01.21 25
1020 [MYSQL] 테이블 스키마 설계 고려사항 졸리운_곰 2022.12.03 33
1019 [MySQL] "아는 만큼 빨라진다" 마이SQL 성능 튜닝 팁 10가지 file 졸리운_곰 2022.11.29 30
1018 [오라클] 오라클 연동 오류 [ORA-01017: invalid username/password; logon denied] 졸리운_곰 2022.11.28 76
1017 [오라클] 제약조건 확인 (FK 찾기) 졸리운_곰 2022.11.28 68
1016 [ADsP] 취업 깡패 ADP 뿌시기! "빅데이터 분석가 최고의 자격증이에요" file 졸리운_곰 2022.11.20 22
1015 [기계학습] [번역] TensorFlow Lite 튜토리얼 3 부 : Raspberry Pi의 음성 인식 졸리운_곰 2022.11.18 7
1014 [기계학습] [번역] TensorFlow Lite 튜토리얼 2 부 : 음성 인식 모델 교육 졸리운_곰 2022.11.18 13
1013 [기계학습] [번역] TensorFlow Lite 튜토리얼 1 부 : Wake Word 기능 추출 졸리운_곰 2022.11.18 10
1012 [기계학습][딥러닝] Generative Adversarial Net (GAN) PyTorch 구현: 손글씨 생성 file 졸리운_곰 2022.11.18 54
1011 [hadoop] Cloudera Quick Start VM in Hyper-V file 졸리운_곰 2022.11.14 14
1010 [기계학습][딥러닝] Flask를 이용하여 파이토치를 REST API로 베포하기 file 졸리운_곰 2022.11.12 44
1009 [기계학습][머신러닝][딥러닝] Vanilla GAN file 졸리운_곰 2022.11.08 13
1008 [기계학습][머신러닝][딥러닝] Generative Adversarial Net (GAN) PyTorch 구현: 손글씨 생성 file 졸리운_곰 2022.11.08 103
1007 [기계학습][머신러닝][딥러닝] DCGAN 튜토리얼 졸리운_곰 2022.11.08 4
1006 [PyTorch] pytorch 기본 문법 및 코드, 팁 snippets file 졸리운_곰 2022.10.20 30
대표 김성준 주소 : 경기 용인 분당수지 U타워 등록번호 : 142-07-27414
통신판매업 신고 : 제2012-용인수지-0185호 출판업 신고 : 수지구청 제 123호 개인정보보호최고책임자 : 김성준 sjkim70@stechstar.com
대표전화 : 010-4589-2193 [fax] 02-6280-1294 COPYRIGHT(C) stechstar.com ALL RIGHTS RESERVED