학교 팀 프로젝트 진행 중 project 테이블에 mockaroo를 이용해서 더미 데이터를 넣는 작업을 진행했는데, project 생성 시 project_team 테이블에 해당 project의 리더 id가 insert 되어야 했다. 1000개의 row에 수작업으로 일일이 넣어주는 건 엄두가 안 나서 MySQL의 저장 프로시저(Stored Procedure)를 사용하기로 했다. 우선 저장 프로시저가 무엇인지 정의부터 알아보고 사용한 프로시저의 내용을 설명하겠다. 저장 프로시저(Stored Procedure)란? 저장 프로시저는 일련의 쿼리를 마치 하나의 함수처럼 실행하기 위한 쿼리의 집합이다. DB에 대한 일련의 작업을 정리한 절차를 RDBMS에 저장한 것으로 영구 저장 모듈이라고도 불린다. 저장 프로시저..
데이터베이스 명명 규칙(Database Naming Conventions) 데이터베이스 설계 작업을 하다보면 어떻게 이름을 명명해야 올바른 네이밍 컨벤션인지 고민하게 된다. 공식적으로 정해진 규칙은 없지만 잘 정리된 글이 해외 사이트에 있어서 나름대로 정리해보려고 한다.(어차피 대부분 기업에서는 기업 내에 컨벤션이 있다고 한다.) 데이터베이스 명명 규칙이 중요한 이유 데이터베이스 구조의 수명은 길다 데이터 구조는 애플리케이션 코드보다 훨씬 오래 지속되는 경우가 많다. 데이터베이스 스키마를 변경하지 않고 새로운 애플리케이션을 개발하는 일은 드물지 않기 때문에 잘 정의된 데이터 구조와 테이블 레이아웃이 중요하다. 데이터베이스 이름은 계약이다. 데이터베이스 개체는 이름으로 참조되므로 개체 이름은 개체에 대한 ..
MySQL DATE, DATETIME, TIMESTAMP 차이점 Mysql에서 데이터 타입을 선택할 때, DATE와 DATETIME 간의 차이는 다들 알고 있지만 DATETIME과 TIMESTAMP 간의 차이점은 헷갈리는 경우가 많다. 그래서 오늘은 이 세 가지 타입에 대해 정리해보려고 한다. DATE DATE는 시간을 제외한 날짜를 저장하는 타입으로 기본 포맷은 ‘YYYY-MM-DD’이며, ‘1000-01-01’부터 ‘9999-12-31’까지 저장할 수 있다. DATETIME DATETIME은 날짜와 시간을 함께 저장할 수 있는 타입으로, 기본 포맷은 ‘YYYY-MM-DD HH:mm:ss’이며, ‘1000-01-01 00:00:00’ 부터 ‘9999-12-31 23:59:59’까지 저장할 수 있다. T..
MySQL 5.1.23 버전 이후로 RENAME DATABASE 구문이 제거되었기 때문에 이미 생성한 데이터베이스의 이름을 변경하고 싶은 경우, 새로운 데이터베이스를 만들어서 그 데이터베이스에 기존 데이터베이스를 옮겨주는 방식으로 가능하다. 1. RENAME TABLE 사용 CREATE DATABASE '새로운 DB명'; RENAME TABLE '기존DB.테이블명' TO '새DB.테이블명'; DROP DATABASE '기존DB명'; 방법은 매우 간단하지만 테이블이 많을 경우 작업을 여러번 해야 한다는 번거로움이 있다. concat을 사용하여 반복 작업을 자동화 하는 방법이 있지만 이 게시글에선 따로 설명하지 않고 MySQL 공식 문서에 있는 방법을 소개한다. 2. mysqldump 사용 $> mysqld..
insert문을 작성하는데 분명 맞게 쓴 것 같았는데 'You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'key' 라는 오류가 떠서 확인해보니 컬럼명이 key라는 예약어와 동일한 이름으로 되어 있어서 예약어로 인식해서 오류가 난 상황이었다. 이런 경우 아주 간단하게 해결할 수 있는데, 쿼리문의 컬럼명 앞 뒤에 `key`처럼 TAB 키 위에 있는 ` 키 ( Single quotation )로 감싸주면 된다. string insertQuery = "insert into table(a,b,`key`) values('1',..
프로젝트 중에 데이터베이스로 MySQL을 사용하게 되었는데 계정을 만들어서 호스트를 %로 주고, 권한을 줬는데도 외부에서 접속이 안되는 상황이 발생해서 하루 내내 구글링을 하면서 고생하고 있었는데, 공유기 사용중인 경우에는 따로 포트포워딩을 해줘야 외부에서 접속이 된다는걸 알았다. 방화벽 인바운드 정책에서만 포트를 열어주면 된다고 생각하고 있었는데 미처 공유기 포트포워딩은 생각 못했었고 검색했을 때도 몇페이지를 뒤지는 동안 그런말은 안나왔으니 혹시 나같은 사람이 있다면 도움되길 바라며.. 공유기를 사용하는 경우에는 공유기 설정 페이지에 가서 3306(MySQL 기본 포트 / 다른 포트 사용시 사용하는 포트)를 열어줘야 한다. 그리고 나같은 경우에는 DDNS를 이용해 도메인도 만들어서 그 주소로 외부에서 ..
회원 테이블을 만드려고 하는데 회원 ID가 최소성, 유일성을 모두 만족하는데 왜 기본키로 회원번호를 따로 만드는지 이해가 안가서 찾아본 결과, 회원이 탈퇴할 경우에 ID가 기본키라면 해당 ID를 신규 가입하는 회원이 사용한다던지의 경우에 곤란한 상황이 생긴다. 그리고 게시글 검색 같은 경우에서도 탈퇴한 회원과 새로 가입한 회원의 아이디가 같아지면 탈퇴한 회원의 게시글까지 같이 검색되는 등 문제가 발생할 소지가 있기 때문에 회원번호 컬럼을 따로 만들어 사용하는 것이다.