ERD? 데이터 모델링 분야에서 개체-관계 모델이란 구조화된 데이터에 대한 일련의 표현이다. "구조"화된 데이터를 저장하기 위해 데이터베이스를 쓴다. 이 데이터의 "구조" 및 그에 수반한 제약 조건들은 다양한 기법에 의해 설계될 수 있다. 그 기법 중 하나가 개체-관계 모델링이다. 출처:위키백과 QuickDBD는 다른 툴과 다르게 프로그래머들을 위해 DB ERD를 쉽게 사용하게 하는데 특화된 툴이라는 것을 느꼈다. Quick DBD를 사용하면서 느낀 점들을 정리해 보았다. 간단한 명령어를 통한 손쉬운 테이블 설계 우리가 직접 모형을 가져오고 테이블에 하나하나 입력하지 않고 명령어를 통해 입력해서 손쉽게 구성이 테이블 설계가 가능해서 작업시간을 효율적으로 사용할 수 있어서 시간을 절약하여 데이터 베이스에 ..
네트워크에 대해 공부하던 중 우리가 브라우저를 통해 웹사이트를 접속할때에 대략적인 부분을 알고 있지만 세세한 부분은 모르는 부분이 있다. 이번 기회를 통해 세세한 부분까지 다시 정리하고자 한다. 출처: https://github.com/JaeYeopHan/Interview_Question_for_Beginner/tree/master/Network 브라우저 우리가 위처럼처럼 네이버를 검색하게 되면 브라우저는 일단 해당 URL의 구조를 분석합니다. 분석한 의미에 따라 Http request 메시지를 만든다. 브라우저는 os를 통해 url을 IP로 변경하게 되는데 과정은 아래와 같다. 자신의 로컬 hosts 파일과 브라우저 캐시에 해당 URL이 존재하는지 확인. 존재하지 않는다면 해당 url을 DNS를 통해 ..
npm을 통해 express를 다운로드하고 express 프로젝트를 생성하면 아래와 같은 구조로 생성하게 되는데 프로젝트를 진행하기 전에 각각 무슨 역활을 하는지 알아 보고자한다. 프로젝트 구조 ├── app.js ├── bin │ └── www ├── package.json ├── public │ ├── images │ ├── javascripts │ └── stylesheets │ └── style.css ├── routes │ ├── index.js │ └── users.js └── views www express의 핵심파일로 아래와 같이 구성되어 있다. var app = require('../app'); var debug = require('debug')('learn-express:server')..
평소에 자바를 공부하면서 백엔드 공부를 하고 있었지만 스타트업은 Python이나 Node.js를 통하여 서버리스 환경을 구축한다. 그렇기에 자바 뿐만 아니라 Node.js에 대해서 좀 더 알아 보려고 한다. Node.js ? 위키에는 아래와 같이 정의 되어 있다. 이 의미를 하나씩 분석 해보았다. "Node.js는 확장성 있는 네트워크 애플리케이션(특히 서버 사이드) 개발에 사용되는 소프트웨어 플랫폼이다. 작성 언어로자바크립트를 활용하며 논블록킹(Non-blocking) I/O와 단일 스레드 이벤트 루프를 통한 높은 처리 성능을 가지고 있다. 내장 HTTP 서버 라이브러리를 포함하고 있어 웹 서버에서 아파치 등의 별도의 소프트웨어 없이 동작하는 것이 가능하며 이를 통해 웹 서버의 동작에 있어 더 많은 통..
OAuth란 유저가 비밀번호나 아이디를 입력하지 않고 다른 웹사이트의 정보로 다른 웹사이트나 어플리케이션의 접근 권한을 부여할 수 있는 즉 웹사이트의 제한된 접근 권한 위임을 다른 웹사이트를 통해 할 수 있도록 만든 프로토콜이다. OAuth2 동작과정 client는 resourceServer에 oauth 사용 요청함 resource서버는 clientID와 client secret 정보를 줍니다. 이를 바탕으로 클라이언트에 client OAuth를 붙이고 나면 사용자가 이를 클릭할 수 있음 resource owner가 클라이언트 접속하면 어떤 정보가 필요하고 승인할지 되묻는다. 승인 버튼을 누르면 owner는 해당 정보를 제공하는 것을 허락할 것인지 묻는다. 승인이 완료되면 server는 클라이언트에게 c..
fetch join이란 SQL 조인 종류 X JPQL에서 성능 최적화를 위해 제공하는 기능 연관된 엔티티나 컬렉션을 SQL 한 번을 통해 조회할 수 있다. 페치 조인 ::= [ LEFT [OUTER] | INNER ] JOIN FETCH 조인경로 엔티티 fetch join 회원을 조회하면서 연관된 팀도 함께 조회 SQL을 보면 회원 뿐만 아니라 팀(T.*)도 함께 SELECT -- [JPQL] select m from Member m join fetch m.team -- 실제 나가는 SQL SELECT M.*, T.* FROM MEMBER M INNER JOIN TEAM T ON M.TEAM_ID = T.ID SQL JPQL fetch join 사용하는 이유 String jpql = "select m f..