일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- 가장 큰 정사각형 찾기
- 12906
- 후보키
- 시저암호
- 카카오 2020 공채
- 문자열을 정수로 바꾸기
- 3954
- 주사위 윷놀이
- 2019 카카오 공채
- 게리맨더링 2
- 정수 내림차순으로 배치하기
- java
- 자연수 뒤집어 배열로 만들기
- 괄호 변환
- 백준
- 투포인터
- 찾아라 프로그래밍 마에스터
- 17779
- 단체사진 찍기
- 짝지어 제거하기
- 자바
- programmers
- 프로그래머스
- 124 나라의 숫자
- 17825
- 라면공장
- Brainf**k 인터프리터
- 2018 카카오 공채
- 카카오2020 공채
- 큰 수 만들기
- Today
- Total
목록CS/DB (5)
기기
토이프로젝트에서 데이터의 생성날짜, 수정날짜 컬럼을 추가하던 중 시간 데이터 타입으로 어떤걸 쓸지 고민하다 간단히 정리 날짜와 시간을 표현하는 타입 MySQL에서는 날짜와 시간을 표현하는 데 여러 가지 타입을 제공 DATE: YYYY-MM-DD 형식으로 날짜만 표현, datetime에서 date만 뽑아낸 것 (Extract the date part of a date or datetime expression) DATETIME: YYYY-MM-DD HH:MM:SS 형식으로 날짜와 시간을 표현 TIMESTAMP: YYYY-MM-DD HH:MM:SS 형식으로 날짜와 시간을 표현하며, 자동으로 값이 업데이트 TIME: HH:MM:SS 형식으로 시간만 표현 YEAR: YYYY 형식으로 년도만 표현 날짜와 시간에 관..
auto increment을 처음봤을 때 이름 그대로 키 값을 알아서 자동으로 올려주는 기능으로만 생각했다. 그런데 막상 사용하려니 동시 요청에 대해 auto increment는 어떻게 대처하는지 원리를 이해못했다. 여기저기 찾아보니 알아둬야 할 내용들이라 생각하여 정리한다 AUTO INCREMENT란 AUTO_INCREMENT 속성을 사용하여 새로운 행에 unique ID 생성 중복되지 않기 때문에 PK에 AUTO_INCREMENT를 많이 설정한다. CREATE TABLE animals ( id MEDIUMINT NOT NULL AUTO_INCREMENT, name CHAR(30) NOT NULL, PRIMARY KEY (id) ); INSERT INTO animals (name) VALUES ('d..
결론 MySQL 8.0 부터 INFORMATION_SCHEMA의 변경 정보는 24시간에 1번 반영된다. 상황 mysql AUTO_INCREMENT 관련 문서에서 sql문을 테스트하던 중 INFORMATION_SCHEMA의 auto_increment 값이 바뀌지 않았다. ALTER TABLE '테이블A' AUTO_INCREMENT = 1; 위와 같이 변경 후 INFORMATION_SCHEMA에서 조회해보니 AUTO_INCREMENT값이 변경되지 않았다. 하지만 '테이블A'에 값을 넣으면 변경된 auto_increment 값이 들어가는 것을 확인할 수 있었다. 이유는 INFORMATION_SCHEMA의 업데이트 속도는 24시간에 1번 반영된다는 것을 알게 되었다. 왜 INFORMATION_SCHEMA 데이터..
필요하지 않은 디비 값까지 조회되는 운영이슈가 있었다. db 쿼리문 조회 시 검색조건에서 예외케이스 있음을 알게된 경험이 있다. 로그부터해서 api 까지 거꾸로 따라가다가 like 절에서 escape 처리가 필요했던 부분이다. 언더바( _ )가 포함된 이름을 조회 시 엉뚱한 결과가 조회될 수 있다. WITH temp AS ( SELECT 'STEVEN_KING' AS ename FROM dual UNION ALL SELECT 'StevenMarkle' AS ename FROM dual ) SELECT * FROM temp WHERE ename LIKE '%_%' 언더바(_)는 LIKE에서 사용하는 패턴 문자이기 때문에 해당 문자를 직접 조회할 수가 없다. 언더바(_)가 존재하는 이름만 검색하였지만 결과는..
맥에서는 homebrew를 이용하면 mysql 설치는 간단하다. homebrew를 설치해두면 다른 프로그램을 설치할 때도 편리하게 설치하고 삭제할 수 있어서 좋다. 1. mysql 설치 $brew install mysql 2. 보안 설정 root 사용자 비번, 원격접속, test 데이터베이스 등 보안관련 설정한다. $mysql_secure_installation 3. mysql 기동 $brew services start mysql 4. mysql 접속 root 권한자로 접속하고 password는 위 2번에서 설정한 값으로 엔터치면 된다. $mysql -u root -p 5. mysql 종료 $brew services stop mysql * mysql 삭제 방법 brew services stop mysql..