이 문제로 많은 고민을 했었는데
MySQL은 SQL Server나 Oracle과 다르게 SP가 처음 한번만 컴파일 되고 재사용 되는것이 아니다.
http://www.joinfu.com/2010/05/mysql-stored-procedures-aint-all-that/
위 링크를 참고하면 커넥션 별로 컴파일이 관리되는데 말인데
즉 어플단에서 쿼리로 실행하나 SP로 실행시키나 컴파일하고 실행하는 과정에서 성능상 이득을 취하긴 어렵다는것!
물론 SP를 사용함으로서 프로그램과 데이터 조작과의 관계를 분리 할 수 있고(추후 SQL 튜닝 및 스키마 수정에 유리)
SP실행 권한만 줌으로서 인젝션과 같은 공격에서 상대적으로 안전하며
짧은 요청 문장으로 인한 트래픽 감소
트리거를 사용하지 않고도 데이터의 참조 무결성 유지
http://ko.wikipedia.org/wiki/%EC%A0%80%EC%9E%A5_%ED%94%84%EB%A1%9C%EC%8B%9C%EC%A0%80
등의 장점은 여전히 남아 있다.
그러면 컴파일 된 프로시저를 그냥 아깝게 버리느냐... 하면
mysql-proxy나 sqlrelay 등을 사용해서 Connection Pool을 구축한다면 커넥션을 한번만 맺고 재사용하기에 극복 할 수 있으니
MySQL을 사용하면 SP는 사용하면 안된다 하지 말고 커넥션 풀을 구축해서 사용하면 커넥션 비용도 감소하고 SP 컴파일도 재사용 가능하니 일석이조의 효과가!!
http://sqlrelay.sourceforge.net/
http://dev.mysql.com/downloads/mysql-proxy/
'프로그래밍 > Mysql\정보' 카테고리의 다른 글
[MySQL] Replication (복제) 동기화 문제 (0) | 2014.10.23 |
---|---|
[Mysql/MariaDB] Percona Xtrabackup 으로 백업/복원하기 (전체,디비별,테이블별) (0) | 2014.05.22 |