2014/11/05 3

[PostgreSQL] PostgreSQL에서 Object 사이즈 관련

PostgreSQL에서 Object 사이즈 관련 PostgreSQL 는 Database, Table, Index 등 물리적인 크기를 확인할 수 있는 편리한 Function들을 제공한다. Funtion Name Description 1 pg_database_size() 데이터베이스 전체 사이즈 계산 2 pg_relation_size() 인덱스, 테이블의 사이즈 계산 3 pg_total_relation_size() 테이블 사이즈 체크시 연관된 인덱스 사이즈까지 합산 [TIP] 위 Function 의 결과값은 Byte 단위로 한눈에 파악이 어렵다. 이 때 pg_size_pretty()라는 유용한 함수를 사용하면 좀 더 파악이 유용하다. [DB의 전체 사이즈] GSM=# SELECT pg_size_pretty(..

MySQL InnoDB Next-Key Locking

InnoDB Next-Key Locking (phantom row 방지 기법) MySQL(InnoDB)의 트랜잭션 모델은 Repeatable Read Isolation 레벨을 기본으로 하고 있다. Repeatable Read는 Read Uncommitted, Read Committed 레벨과는 달리 Phatom Row가 발생하지 않는다는 장점이 있다. Phantom Row의 "Phatom"은 유령이라는 뜻으로, 아래와 같이 트랜잭션 수행중 다른 트랜잭션이 생성한 Row가 갑자기 나타나는 것을 말한다. 아래 예제에서는 Phantom Row를 만들기 위해 세션의 Isolation 레벨을 Read Committed로 변경하고, 2번째 SELECT 쿼리를 수행하기 전에 다른 트랜잭션에서 새로운 값을 INSERT..