입문주차를 끝내고, Node.js숙련 주차에 해당하는 강의 !
에 대한 이야기를 하기에 앞서서,
CH3 의 개인과제에 해당하는 내용이 오늘 공개가 되었다.
과제의 발제 자체는 내일이지만, 어쨌든 해야할 과제가 무엇인지는 공개가 되었다.
그 과제는 이름하야...
CH 3 아이템 시뮬레이터 과제 !!!
학습 과제를 끝내고 나면 할 수 있어요! ==> 이걸 모르면 과제를 할 수 없어요 !
발제는 내일이기 때문에 간략하게만 살펴 보았는데,
Expreess 로 서버 와 api 구성
AWS RDS -> MySQL 을 사용하여 데이터 베이스를 활용
Prisma를 사용하여 데이터 베이스 컨트롤
AWS EC2 를 이용한 배포
와 같은 내용으로 구성되어 있었으며
조금 더 구체적으로 들어가면,
1. 회원가입 및 로그인 기능
2. 캐릭터 생성 및 캐릭터의 능력치 설정
3. 캐릭터 상세 조회와 캐릭터 삭제 기능
4. 아이템 생성
5. 아이템 수정 (강화..?)
6. 아이템 목록 조회 및 아이템의 상세정보 조회
도전기능으로는
1. 아이템 구매 및 판매
2. 인벤토리 기능
3. 장착 아이템 목록 조회
4. 아이템 장착 및 탈착 API
5. 게임머니 획득 API
이걸 만들라구요 ?!
어라... 이 감정...?
그렇지만 이번에는 정말로 어려울것 같다는 느낌이 든다...
따로 스켈레톤 코드 같은 것이 지급되지 않는것으로 확인이되어,
더 감이 안잡히는것 같다.
중요한건 강의를 서둘러서 들어야 한다는거임
관계형 데이터베이스
오늘 배운 내용은 전부 여기에 해당한다고 볼 수 있다.
저번시간에 학습했던 비관계형 데이터베이스인 mongoDB 와 달리
관계형 데이터 베이스에 해당하는 Mysql을 기반으로 학습을 진행했다.
관계형 데이터 베이스에 해당하는 Mysql 은 이전에 입문단계에 해당하는 강의를 학습한 적이 있다.
때문에 비교적 이해하는데 큰 어려움은 없었다.
차이가 있다면, 입문강의에서 진행했던 내용은 DBeaver 를 통해 이미 작성된 database 를 조회하는
방법 위주로 강의가 진행되었기 때문에, 내용을 따지고 보면 오늘 학습하는 내용과 차이가 꽤 크다고 볼 수 있다.
오늘은, 실제로 MySQL 데이터베이스를 AWS RDS 를 통해 직접 구동하여 (대여해서...)
Database 와 table, 그리고 column 에 해당하는 부분을 직접 추가하거나 수정하고, 삭제하는 과정을 학습했다.
VScode 에서 SQL 언어을 사용할 수 있고,
MYSQL 확장 프로그램을 통해 VScode 내에서 사실 다 할 수 있다.
마이크로 소프트.. 그는 대체...
오늘 미약한 공포가 느껴졌던 부분
그것은 바로 Raw Query 라고 할 수 있다.
언뜻 보면, 노드 환경에서 직접 SQL 요청을 보내는 평범한 기능으로 생각이 되지만,
// app.js
/** 테이블 생성 API **/
app.post('/api/tables/', async (req, res, next) => {
const { tableName } = req.body;
await connect.promise().query(`
CREATE TABLE ${tableName}
(
id INT NOT NULL AUTO_INCREMENT PRIMARY KEY,
name VARCHAR(20) NOT NULL,
createdAt DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP
)`);
return res.status(201).json({ message: '테이블 생성에 성공하였습니다.' });
});
이런식으로 Raw Query 를 작성하다 보면, 이건 좀 아닌것 같다는 생각이 스멀스멀 들기 시작한다.
강의에서는 Raw Query 최대 단점을, 유지보수가 어려운 점을 꼽았는데,
예를 들면,
createdAt 라는 칼럼이 createDate 라는 칼럼명으로 바뀌어야 한다고 가정해 보자.
우리는 Raw Query로 작성한 createdAt를 전부 찾아서 createDate 로 수정해야만 할 것이다.
그냥 바꾸지 말죠? 에서 부터,
최악의 경우, 한 두가지를 놓치는 바람에 서버가 다운되거나 데이터가 변조될 위험성도 있다.
ORM 등장 (Object Relational Mapping)
앞선 문제들에 대한 대책으로 ORM이 개발되었고, 강의에서는 ORM 중 하나인 Prisma 를 소개해 주었다.
ORM 의 최대 장점은, 데이터 베이스가 통째로 바뀌더라도 유연한 대처가 가능하며, ( ex MySQL -> Oracle)
위에 언급된 문제인 Table 또는 cullum 의 수정 정도는 어렵지 않게 대처할 수 있다.
Node에서 Prisma를 설치할 경우,
schema.prisma 을 내용을 토대로 database 를 추가하거나 수정할 수 있게 된다.
Posts 라는 새로운 table 과 각 cullum 의 설정을 작성한다.
SQL 과 Raw Query 사이 어딘가....로 보이는 형태의 언어이지만,
성능이 확실하다고 설명했기 때문에 왠지 호감도가 올라간 상태 !!
이렇게 schema.prisma에 작성한 내용을
npx prisma db push 명령을 통해 push 하면,
node_modules/.prisma/index.d.ts 의 어딘가에
JS 형태로 작성이 되어진다.
(이 외에도 예상했던것 보다 많은것이 기록된다...)
Prisma를 통해 Posts table과 각 컬럼 속성 설정에 성공한 결과 !
오늘 학습한 내용은 여기까지 인데, 아무래도 과제 발제 까지 시간이 촉박 하기 때문에,
며칠정도는 TIL 의 작성시간을 줄이고 강의를 더 듣는다거나,
주말을 포기한다거나 하는 일이 발생할 것 같다...