ORM을 이용하기 위해서는 Object modeling과 Relational modeling, 두 Modeling의 차이점을 이해해야만 한다.
Object Modeling
Object Modeling은 OOP를 기반으로 생성된 시스템을 표현한다.
기본 개념
Identity, State, Behavior, Encapsulation
높은 레벨의 개념
Type, Associations, Class, Inheritance
Relational Modeling
Relational Modeling은 서술어와 비슷한 truth statement로 정보를 표현한다.
기본 개념
Relation, Attribute, Domain, Tuple, Attribute Value( attribute value는 각각의 tuple에 포함된 attribute의 value들 이다 ), Relation Value, Realtion Variable, Database, Base Relation Values, Derived Relation Values, Coupling between relations, variables, and values
Database와 Relational Modeling의 기본적인 개념 비교
Common Database | Relational |
table | relation Variable |
row | tuple |
column | attribute |
column value | attribute value |
database | database |
ORM이란?
ORM이란 용어에도 나와있듯이 객체(Object)와 관계(Relation)을 연결(Mapping)해 주는 개념이다.
객체와 테이블 시스템(RDBMSs)을 변형 및 연결해주는 작업이라 말 할 수 있다.
ORM을 이용한 개발은 객체와 데이터베이스의 변형에 유연하게 대처할 수 있도록 해준다.
ORM을 객체 지향 프로그래밍 관점에서 생각해보면, 관계형 데이터베이스에 제약을 최대한 받지 않으면서, 객체를 클래스로 표현하는 것과 같이 관계형 데이터베이스를 객체처럼 쉽게 표현 또는 사용하자는 것이다.
Transparent Persistence
ORM에서, object programming language를 사용한 relational database에 저장된 데이터를 직접 조작하는 것을 Transparent Persistence라고 한다. Transparent persistent는 ODBC 또는 JDBC등을 사용하는 database sub-language와는 다르다.
ORM의 기본적인 개념에서 객체와 관계에 대한 이야기를 토대로 했을 때, transparent persistence가 비로써 이해가 된다.
Transparent persistence는 O-R Mapping tool이 관계형 데이터베이스에 저장된 데이터를( 오브젝트 프로그래밍 언어를 통해 )
직접 조작하는 기능이다.
ORM의 등장 배경
ORM이 등장하기 전 까지의 개발 방식
| Model 1 개발방식 | Model 2 개발방식 | ORM 개발방식 |
설명 | 초기 데이터 베이스 개발 모델 | MVC 모델에서의 데이터 베이스 개발 모델 | Persistence Layer를 담당하는 Framework 개발 모델 |
기능 | JSP, Servlet에서의 persistence layer 처리 | DAO, EJB(CMP)를 이용한 persistence layer 개발 | iBatis, Hibernate와 같은 persistence를 담당하는 Framework 개발 |
장점 | 배우기 쉽다. 빠른 시간 내에 개발 할 수 있다. | MVC 모델 적용이 가능하다. 객체 단위의 개발이 가능하다. | 객체지향적 프로그래밍이 가능하다. Query를 용이하게 처리. Business layer에 집중할 수 있다. |
단점 | 복잡도 증가, 유지보수가 어렵다. 비 객체지향적 프로그래밍 | MVC/EJB에 대한 이해가 필요하다. 유지보수가 어렵다. | Framework을 배워야 한다. |
Java에서 웹 애플리케이션을 개발할 때 처음에는 JSP/Servlet에 View와 Business logic, 데이터 베이스 처리 모듈까지 모두 포함하여 개발함으로써, 유지보수의 어려움과 같은 많은 문제점이 발견되어 진다.
따라서 MVC 모델에 입각한 각 Layer를 구분하여 개발자로 하여금 business logic에 집중할 수 있는 컴포넌트와 같은 형태들이 제공되어 지는데, SUN에서는 J2EE 스팩안에 EJB를 넣음으로써 persisten layer를 컨테이너에게 담당하게 함으로써 이와 같은 문제점을 해결하고자 했다.
하지만 Model 2방식에서 이와 같은 접근은( 특히 EJB-CMP ) 각 WSA( Web Application Server ) 제품에 따른 deploymement descriptor 파일을 각각 수정해야 하고, 낮은 개발자 생산성, 테스트의 어려움 등 다양한 단점이 발생하게 된다. 뿐만 아니라 각 WSA에 따른 컨테이너의 처리 방식이 상이함에 따라 개발자들은 EJB 뿐만 아니라 WAS에 대한 이해도 요구하게 되었다.
이러한 하나의 대안으로 DAO 클래스를 두고 데이터 베이스와의 처리를 DAO에서 처리하게 된다.
DAO 클래스에서는 개발자의 특성에 따라서 트랜잭션 처리, Connection Poll 처리 등을 상이하게 개발하게 된다.
그리고 현재 ORM 프로그래밍 기법에 따른 persistence layer를 처리하는 Hibernate, iBatis, Oracle TopLink와 같은 Framework이 등장하게 된다. EJB의 대안으로 등장하게된 이와같은 Framework은 각 Framework에 구현 방식에 따라 Query, Connection, Transacation 처리 등을 Framework가 처리해 줌으로써 개발자로 하여금 business logic에 집중할 수 있도록 제공해 주게 된다.
하지만 이러한 프레임워크를 공부해야 하고 적응하는 데에도 시간이 필요하고, 경우에 따라서 유지보수의 어려움이 따르게 된다. 그러므로 각 개발환경에 맞는 적절한 개발 방식을 선택할 수 있는 능력이 필요하게 된다.
왜 ORM인가?
- ORM을 이용하면 CRUD를 위해 긴 SQL 문장을 작성할 필요가 없다. 쿼리 작성은 여전히 필요하지만,
ORM 툴(HQL 등)을 이용하면 한층 쉽게 만들 수 있다. 또 JDBC와 관련된 복잡한 코드 작업으로부터 해방될 수 있다.
- ORM을 이용하면 관계형 모델과 관련된 성능 오버헤드를 수반하지 않고도 요구사항에 적합한 도메인 모델을 생성할 수 있으며,
로우와 컬럼이 아닌 오브젝트의 관점에서 작업을 수행하는 것이 가능한다.
- ORM은 변경 사항을 자동으로 감지하므로, 전체 개발 라이프사이클에 걸쳐 에러의 가능성을 줄일 수 있다.
- ORM은 데이터베이스 벤더 별로 제공되는 SQL 구문에 대한 종속성을 줄이고 호환성을 향상시켜 준다.
SQL 구문은 ORM 툴에 의해 추상화가 가능하다.
ORM 사용 선택을 위한 가이드 라인
적절하게 활용되는 경우, ORM은 개발 작업에 투자되는 인력을 절감하고 관리 능력을 개선하는 효과를 제공한다.
JDBC 대신 ORM 솔루션을 적용함으로써 작성하는 코드의 양을 30~50% 정도 절감하는 효과를 볼 수 있다.
이렇게 절감된 인력을 비즈니스 기능의 구현에 투자할 수 있다는 점에서, ORM 솔루션은 분명한 효과가 있다.
ORM이 적절하게 사용되기 위한 방법
타겟 데이터베이스를 이해하라
- ORM을 적용할 때, SQL 및 데이터베이스의 락킹(locking) 모델을 무시하면 안된다. O-R 매핑은 작업을 쉽게 해 주는 툴이지, 구현되는 환경에 대한 이해를 불필요하게 만드는 툴은 아니다.( ORM 적용 환경에서 발생하는 많은 문제가 데이터베이스와 SQL의 문제를 간과함으로써 발생한다. )
필요한 경우 SQL을 사용하는 것을 두려워하지 마라
많은 경우에서 이 방법으로 효과를 볼 수 있다. Hibernate, TopLink와 같은 ORM 제품은 SQL 쿼리 작성 기능을 제공한다. 하지만 경우에 따라 SQL문을 직접 작성해야 할 경우도 있다.
O-R 매핑 제품을 선택하기 전에 충분히 검토하라
모든 ORM 제품이 동일한 수준의 기능을 제공하는 것은 아니다. 요구 사항을 반영하는 환경을 구축하고 2~3가지 제품을 비교 테스트해 봐야 한다. 이 과정을 통해 ORM이 성능 기준을 만족하는지 검증할 수 있다. 엔터프라이즈 개발 과정의 다른 요소들과 마찬가지로, 프로젝트 라이프사이클의 초기 단계에서 성능과 관련된 리스크를 최소화하는 것이 중요하다.
또 ORM 툴의 매핑 기능에 과도한 오버헤드가 수반되지 않는지 확인해야 한다.
ORM이 적절하게 사용될 수 있는 상황을 이해하라
ORM은 엔티티를 개별적으로 업데이트하고 간헐적으로 셋 기반 작업을 수행하는 OLTP 애플리케이션에 특히 적합하다.
ORM이 적절하지 않은 경우를 이해하라
ORM이 적합하지 않은 경우
▷ 많은 수의 레코드에 대해 잦은 빈도로 벌크 업데이트를 수행하는 애플리케이션
- OLAP 애플리케이션
▷ 데이터 마이닝을 위해 사용되는 어플리케이션에서는 이미 데이터를 본래의 엔티티 상태로 사용하기 어렵다.
- 데이터의 인출 및 업데이트를 위해 핸드코딩으로 작성된 SQL 및 저장 프로시저를 이용하는 데이터베이스 환경
이 경우 JDBC 기반의 접근 방법이 최선의 선택이 될 수 있다. iBATIS SQL Maps 역시 이러한 환경에서 빛을 발한다
하지만 몇몇 ORM 제품은 기존 스키마 및 저장 프로시저와 효과적으로 연동될 수 있으므로, 이러한 환경에서도 ORM의 사용을 고려할 가치가 있다.
▷ 순수 SQL 기반 접근 방법을 적용하는 것이 적절한 애플리케이션
- 비즈니스 로직의 대부분이 데이터베이스에 이미 구현되어 있거나, 데이터베이스 무결성 제약( integrity constraint )이 적용되어 있는 경우 등을 그 예로 들 수 있다. 이러한 애플리케이션에서는 오브젝트 또는 ORM의 활용 여지가 매우 적으며, 데이터베이스 테이블을 도메인 오브젝트로 모델링 함으로써 기대할 수 잇는 효과가 거의 없다.
[출처] [ORM] ORM이란?|작성자 진탄
https://stackoverflow.com/questions/1984548/hibernate-vs-ibatis
'Web > 스프링' 카테고리의 다른 글
[mybatis] ibatis -> mybatis 트랜잭션 관리 (0) | 2019.11.20 |
---|---|
스프링 <context:component-scan> 분석 (0) | 2019.05.07 |
Spring - 어디에서나 Spring 컨터이너 Bean 객체 얻어오기 (0) | 2019.03.15 |
[mybatis] selectmap 해결방안 못찾음.. (0) | 2018.12.06 |
log4j2.properties 프로퍼티 완료 예제. 트러블슈팅 내용 포함 (0) | 2018.11.29 |
댓글