본문 바로가기
풀스택 개발/풀스택

ORM이란?

by act2 2024. 11. 10.
728x90

ORM(Object-Relational Mapping)은 객체 지향 프로그래밍 언어에서 데이터베이스와 상호작용할 때 객체와 관계형 데이터베이스의 데이터를 매핑하는 기법입니다. ORM을 사용하면 개발자는 데이터베이스의 테이블과 레코드를 객체로 다룰 수 있어, SQL 쿼리를 직접 작성하는 것보다 더 직관적으로 데이터베이스 작업을 수행할 수 있습니다.

 

ORM의 주요 특징

객체 지향적 접근: ORM은 데이터베이스의 테이블을 객체로 표현하고, 레코드를 객체의 인스턴스로 변환합니다. 이를 통해 개발자는 객체 지향 프로그래밍의 장점을 활용할 수 있습니다.

  • 추상화: ORM은 데이터베이스 작업을 추상화하여 SQL 쿼리를 직접 작성하지 않고도 데이터베이스에 접근할 수 있도록 해줍니다. 이는 코드의 가독성을 높이고 유지보수성을 향상합니다.
  • 데이터베이스 독립성: ORM을 사용하면 특정 데이터베이스에 종속되지 않고 다양한 데이터베이스 시스템에서 사용할 수 있는 코드를 작성할 수 있습니다. ORM 프레임워크는 데이터베이스에 맞는 SQL 쿼리를 자동으로 생성합니다.
  • 편리한 CRUD 작업: Create, Read, Update, Delete와 같은 기본적인 데이터베이스 작업을 간편하게 수행할 수 있는 메서드를 제공합니다.

 

ORM의 장점

  • 생산성 향상: SQL 쿼리를 작성하는 데 드는 시간을 줄여주어 개발 속도를 높입니다.
  • 유지보수 용이: 객체 지향의 특성을 활용하여 코드 구조를 명확하게 할 수 있습니다.
  • 타입 안전성: 컴파일 타임에 오류를 발견할 수 있어 런타임 오류를 줄일 수 있습니다.

 

ORM의 단점

  • 성능 문제: 복잡한 쿼리나 대량의 데이터를 처리할 때 성능 저하가 발생할 수 있습니다.
  • 추가 학습 필요: ORM 프레임워크의 사용법과 개념을 익히는 데 시간이 필요할 수 있습니다.
  • SQL 최적화의 어려움: ORM이 자동으로 생성하는 SQL 쿼리가 최적화되지 않을 수 있어, 성능 개선이 필요한 경우 직접 SQL을 작성해야 할 수도 있습니다.

 

대표적인 ORM 프레임워크

  • Hibernate: 자바 기반의 ORM 프레임워크.
  • Entity Framework: .NET 환경에서 사용하는 ORM.
  • Django ORM: 파이썬 Django 프레임워크에 내장된 ORM.
  • SQLAlchemy: 파이썬에서 사용할 수 있는 강력한 ORM과 SQL 도구.

 

ORM은 데이터베이스와의 상호작용을 단순화하고 객체 지향 프로그래밍의 이점을 살리는 데 유용한 기술입니다.

728x90