PostgreSQL

공식 홈페이지

1. 소개
2. 현재 사용자들
3. 기타

1. 소개

The PostgreSQL Global Development Group에서 개발하는 오픈 소스 RDBMS. 1996년에 첫 출시되었다. 처음에는 BSD 라이선스였으나 언제부터인가 MIT 라이선스 비스무리한 독자적 라이선스[1]를 따르기 시작했다. 발음은 '포스트그레스큐엘'이라고 한다.

전 세계 사용률은 상위 3개의 DB(Oracle DB, MySQL, Microsoft SQL)에 이어 4위인데, 꾸준히 상승하고 있는 것이 특징이다. 비교적 사용률이 높은 국가는 북미일본. 북미에서는 MySQL과 반대로 꾸준히 구인률이 증가하고 있으며, 일본에서는 관공서에서 사용할 경우 상용은 오라클 데이터베이스, 무료는 PostgreSQL를 사용한다는 말이 있다. 특히 일본의 기성 세대 엔지니어들은 초기부터 PostgreSQL를 사용해오고 있으며 젊은 층 개발자들 역시 2009년에 썬 마이크로시스템즈오라클이 인수하면서 MySQL 소유권에 대한 이슈 때문에 PostgreSQL을 주로 사용한다.

MySQL에 비해서 SQL 표준을 더 잘 지원하고 기능이 더 강력하며[2] 쿼리가 복잡해질수록 성능이 더 잘 나오는 편이다.[3] 특히 PostGIS를 통한 Geospatial query는 오라클마저 씹어삼키는 강력함을 자랑하며, Citus 익스텐션을 이용하면 그동안 약점으로 지적돼왔던 병렬 인덱싱도 손쉽게 처리 가능하다.

여러 DBMS 중에서도 특히 개발자들이 선호하는 편이며 충성도가 높은 편이고 여러 나라에서 개최되는 컨퍼런스나 세미나도 꾸준한 편이다.

최근 애플은 MySQL이 오라클에 넘어가면서 향후 일어날지도 모를 저작권 분쟁을 방지하기 위해 OS X Lion Server 버전에서는 MySQL을 퇴출시키고 PostgreSQL를 도입하였다. 양 DB간 Migration도 쉬운 편이다.

2. 현재 사용자들

이렇듯이 일본 외에도 생각보다 많은 사용자를 가지고 있다.

3. 기타

터미널 창에 'psql'을 입력하면 기본 슈퍼유저인 postgres로 접속하는 게 아니라 현재 로그인되어 있는 운영체제의 계정으로 접속을 시도하여 에러 메시지를 띄운다. 이 에러가 보기 싫다면 직접 postgres로 접속한 후 해당 계정명과 일치하는 데이터베이스 및 유저를 생성해 주면 된다.


  1. [1] PostgreSQL License http://www.postgresql.org/about/licence/
  2. [2] 예를 들면 MySQL에는 CTE나 Check constraint 등이 없다. CTE는 각각 MariaDB 10.2, MySQL 8에서 구현되었으며 Check constranints는 MariaDB 10.2에서 구현되었다. MySQL은 현재까지도 Check constraints가 없다.
  3. [3] Genetic query optimizer라고 불리는, 유전 알고리즘을 통한 쿼리 최적화 기술이 구현되어 있다. MySQL과의 성능 비교