.
잘 아시는 분이 많을 텐테 답변이 없으시네요.
LDAP에서 사용하는 BackEnd DB의 속도의 차이 때문일 수 있습니다.
OpenLDAP은 버클리DB를 사용하는데 이 모듈이 속도가 좀 나거든요.
그리고 LDAP의 쿼리가 SQL 쿼리보다 간단해서 그런 결과가 나왔을 겁니다.
뭐라고 설명을 할까요?
음 OpenLDAP과 SunONE LDAP은 Attribute마다 데이터베이스를 가지고 있습니다. 그리고 각 Attribute를 통합하는 하나의 데이터베이스를 가지고 있고요. 하나의 Attribute로 검색을 했다면 LDAP을 이 하나의 어트리뷰트가 저장된 DB에서 데이터를 검색한 후 전체 데이터가 들어있는 파일에서 값을 다 가져오지요... 그래서 DB보다는 빠를 겁니다. 하지만 500만개 이상의 데이터를 가지고 있고 이중 400만개를 쿼리를 한다면 당연히 RDB가 바르겠지요..
제가 DB문서나 공부자료에 비교한 점을 올려 놓은거 같은데 한번 찾아보세요... 그럼
버클리DB는 이진트리와 해시 테이블의 조합으로 동작하기 때문에 탐색 속도는 대단히 빠릅니다. 이진트리와 해시 테이블은 자료구조론 서적을 보시거나 웹 검색을 해보셔도 쉽게 찾을 수 있을 겁니다.
LDAP의 검색 속도가 빠른 것은 바로 그런 백엔드 DB 때문이기도 하지만 LDAP이라는 프로토콜이 그런 단순 탐색에 최적화되어 있기 때문이기도 합니다. 말 그대로 디렉토리죠. 전화번호부를 생각하시면 됩니다. 반면, 오라클과 같은 DBMS는 복잡하게 상호연관된 자료를 대상으로 하기 때문에 LDAP 과는 그 지향점이 다릅니다.
단순한 쿼리의 경우 LDAP과 비교하여 어느정도나 차이가 나는지 모르겠습니다만 혹시 오라클의 속도가 의심스럽다면 좀더 복잡한 자료를 대상으로 복잡한 쿼리를 주어 테스트해 보세요. 그래도 여전히 속도가 의심스러우면 오라클 게시판에 질문을 올려 보세요. 그것은 오라클의 튜닝과 관련한 주제일 테니까요 :)
(위의 글을 쓰는 동안 상준님이 또 답변을 올리셨네요. -_-; 저와 동시에 쓰고 있었나봐요.)