[TIL] ORM - Sequelize

이재훈·2020년 10월 27일
0
post-thumbnail

자바스크립트를 배우고 있는 예비 개발자입니다.
수정할 부분이 있으면 알려주시면 감사드리겠습니다 :)

What I Learned Today :)

  📌  ORM
  📌  Sequelize



Object Relational Mapping

🌱  ORM 이란?


ORM
Object Relational Mapping의 줄임말이다.
객체와 model사이에서 통역사 역할을 하고 있는 ORM은 관계형 데이터베이스의 엔티티, 레코드에 접근할 때 객체 혹은 class를 다루듯이 취급할 수 있다고 한다.
즉, 객체와 관계형 데이터베이스 사이에서 데이터베이스에 저장된 정보를 매핑해주는 역할을 한다.

🌱  ORM의 장,단점

장점

  • NoSQL. 즉, SQL문을 사용안하고도 데이터베이스에 접근 할 수 있음.
  • 객체 지향적 코드로 SQL문보다 더욱 직관적임.
    - Model별로 코드 분리 -> 가독성 향상
    - SQL문처럼 한없이 길어지지 않는다.
  • 재사용 및 유지보수 효율성 증대
    - ORM으로 작성한 객체들은 재사용이 가능

단점

  • 막상 구현해보면 코드가 몇 줄 안되는 경우도 있지만, 구현 과정에는 신중해야함
    (잘못된 구현으로 속도 저하 등 성능 저하 우려)
  • 복잡한 프로젝트일 수록 복잡한 쿼리문을 작성하게 되고 그만큼 난이도 상승,
    (오히려 SQL문으로 사용이 직관적일 수도 있음)

🌱  Sequelize는 무엇인가요?

(공식문서: https://sequelize.org/master/)

특징

  • Node.js기반 ORM
  • Promise 기반으로 비동기 제어가 가능 (데이터를 받아오는 과정에 적합!)
    - Chaining을 통해 복잡한 비동기 코드를 깔끔하게 만들어주고, 연속되고 일련의 작업이 가능
  • Postgres, MySQL, MariaDB, SQLite, Microsoft SQL Server 등 RDBMS(Relational Database Management System)을 지원한다.
    여기서 위의 소프트웨어들은 SQL문이 미세하게 다른데, Sequelize로 인해 통일된 코드 및 명령어 작성 가능 (호환성 통합!)
RDBMS(Relational Database Management System): 관계형 데이터베이스를 생성, 수정 및 관리를 가능하게 하는 소프트웨어
  • Sequelize CLI로 데이터베이스 작업
    - Mac 터미널과 같이 명령어로 작업을 하는 CLI와 동일한 개념으로 Sequelize도 CLI로 데이터베이스에 접근, 생성 및 작업을 하여 스키마 작업 혹은 모델링을 할 수 있다.

SQL 쿼리문을 Sequelize에서는 아래와 같이 작성할 수 있다.

* INSERT queries

// Create a new user
const jane = await User.create({ firstName: "Jane", lastName: "Doe" });
console.log("Jane's auto-generated ID:", jane.id);

* SELECT queries

// Find all users
const users = await User.findAll();


* DELETE queries

// Delete everyone named "Jane"
await User.destroy({
  where: {
    firstName: "Jane"
  }
});

* UPDATE queries

// Change everyone without a last name to "Doe"
await User.update({ lastName: "Doe" }, {
  where: {
    lastName: null
  }
});


*** Applying WHERE clauses

Post.findAll({
  where: {
    authorId: 2
  }
});
// 기존 SQL문 - SELECT * FROM post WHERE authorId = 2 


[출처]
https://sequelize.org/master/manual/model-querying-basics.html

Potter's thought!

실무에서 많이 사용된다는 MVC pattern과 ORM, Sequelize를 배워봤다.
음.. 이번 스프린트를 진행하면서 느낀 점은 막상 코드 구현을 해보니 예상 외로 코드가 짧아 허탈했지만 구현 과정 즉 설계하는데에 꽤 신중을 기했어야 했다. 특히 Controller에서 많은 시간을 투자했었다.

쉽지않을 것이라 예상은 했지만
역시나 어려웠다. 더 연습하자!

Ps) Sequelize 공식문서 가독성 은근히 헬이다.

⭐️   MVC Pattern 포스트 바로가기


[참고]
https://velog.io/@alskt0419/ORM%EC%97%90-%EB%8C%80%ED%95%B4%EC%84%9C...-iek4f0o3fg

[더 읽어보기]
https://medium.com/graphql-seoul/%EB%B2%88%EC%97%AD-%EB%A7%88%EC%9D%B4%EA%B7%B8%EB%A0%88%EC%9D%B4%EC%85%98%EA%B3%BC-sequelize-cli-%ED%8A%9C%ED%86%A0%EB%A6%AC%EC%96%BC-3926c0a9eae6

profile
코딩에서 인생을 배우다.

0개의 댓글

관련 채용 정보