본문 바로가기

Project

(13)
어떻게 데이터를 건드릴 수 있을까? 회사에서 데이터베이스 커넥션을 받고 쿼리를 작성해서 CRUD를 진행했습니다. TypeORM을 한 번도 사용해보지 않은 저는 어떤 방식으로 데이터를 건드릴 수 있을지 찾아보았습니다. 물론 이전 글에서 어떻게 접근하는지 약간씩 등장하긴 합니다. 자 이제부터, 데이터에 접근할 수 있는 방법 4가지에 대해서 글을 작성하도록 해보겠습니다. 4가지가 무엇인지 먼저 말씀드리고 글을 작성하겠습니다.첫번째, QueryRunner두 번째, Entity Manager세 번째, Repository네 번째, Query Builder순서대로 설명드리겠습니다.더보기약간의 배경지식코드에서 맨 위에 나오고 객체 불러올때 쓰이는 DataSource란 무엇인가? TypeORM에서 데이터베이스 연결 설정을 관리하는 객체입니다. 연결한 데이..
왜 ORM을 사용하려고 하는데요? ORM을 통해서 SQL 쿼리 없이 데이터를 데이터베이스에 저장하고 관리할 수 있게 되었습니다.그래서 개발자는 더욱 편해지게 되었던 것이었죠. 익숙한 언어로 데이터베이스의 데이터를 더 쉽게 조작할 수 있게 되었으니까요.더보기 'ORM을 배워야 하는 것은 문제가 되지만요? 사실은 SQL도 잘 짤 수 있어야 하기도 합니다. 사실 배워야 할 것이 늘었다고 볼 수 있습니다. 지금 당장 저도 배우고 있긴 하거든요..'근데 사실 ORM은 어떤 역할을 담당하냐면?애플리케이션은 객체로 데이터 처리반면에, 데이터베이스는 테이블로 데이터 처리어라? 서로 다르네?위와 같은 패러다임(paradigm)의 불일치를 ORM이 가운데에서 딱 조절을 해줍니다. 그래서 ORM이 뭔지에 대해서 조금 더 심화과정을 작성해보려고 합니다. 이래..
너랑 나랑 무슨 관계(relation)야? 제목이 심상치 않습니다. 이런 연락을 받아보신 적 있으신가요? 저는 없습니다. 어쨌든 별건 아니고 객체 간의 관계를 의미하는 것입니다. ORM에서는 여러 가지 관계가 존재하는데요? 그 관계들을 정리해 보도록 하겠습니다.여기서 설명 드릴 관계는 총 세 가지입니다.첫 번째, 일대일(@OneToOne())두 번째, 일대다(@OneToMany(), @ManyToOne())세 번째, 다대다(@ManyToMany()) 가 되겠습니다. 천천히 작성을 해보도록 하겠습니다. 왜 천천히 작성이냐면, 제가 아는 지식에서 더 늘어나거나 잘못된 지식인 것을 발견하거나 하면 차근차근 추가 또는 삭제해 나갈 것이기 때문입니다. 그래서 천천히 작성해 보겠다고 글을 먼저 작성해 봤습니다. 아래부터는 순서대로 작성해 보겠습니다.나도 하..
왜냐하면, ORM을 사용하기로 했다. 왜냐하면, ORM을 사용하기로 했다. 그중에서도 많고 많은 ORM 중에 TypeORM을 사용하기로 했다. 사용하기로한 이유를 아래 차례대로 나열해 보겠습니다.첫 번째, 데이터베이스와 상호작용하는 코드가 더 직관적인고 유지보수의 이점을 준다.두 번째, 자동화된 데이터베이스 스키마 관리와 타입 안전성을 제공해 개발자가 더욱 생산적이고 안전하게 코드를 작성할 수 있다.세 번째, 직접 SQL을 작성하는 경우보다, 코드의 복잡성이 줄어들며 여러 데이터베이스를 지원하여 유연성을 확보할 수 있다.위의 세가지 이유는 여러 블로그를 읽어보며 나와 있는 내용이다. 하지만, 가장 중요한 이유 중 하나는 이것이다.한 번도 사용해보지 않았기 때문에 사실 위의 세가지 이유는 형식적으로 작성을 할 수밖에 없습니다. 왜냐하면, 누군..
가상환경(Virtual Environments)이란? 파이썬? 가상환경? 이게 뭐야? 조금만..알아보자 4가지가 존재하는지도 몰랐다. 가상 환경(Virtual Environment)? 가상 환경은 독립적인 파이썬 실행 환경을 의미합니다. 각각의 가상 환경은 다른 황경에 영향을 미치지 않으며 각자 다른 종류와 버전의 패키지를 가질 수 있습니다. 가상 환경은 왜 필요한가? 프로젝트를 배포하면서 원격 서버에 따로 패키지를 설치해 줘야 하는데, 이 프로젝트가 사용한 패키지가 무엇인지 모른다. 내가 프로젝트를 할 때 사용했던 버전과 배포시 사용할 버전이 정확히 일치하는지 모른다. 시간이 지남에 따라 패키지가 업데이트 되는데, 서로 의존적인 패키지들 사이에 버전이 맞지 않을 수 있다. 등등...이 존재하게 된다. 가상환경의 종류를 알아보자 1. venv 초심자들에게 ..