목록Database/MySQL(Maria DB) (5)
IT 성장일기

MySQL, MariaDB에서 Merge 구문 구현하기Merge가 머지?키를 비교해서 행이 이미 존재한다면 UPDATE를, 존재하지 않으면 INSERT를 수행하는 구문을 의미합니다.Oracle이나 SQL Server에는 Merge 구문이 존재하지만 MySQL에서는 조금 다른 방법으로 같은 동작을 수행할 수 있습니다.INSERT ~ ON DUPLICATE KEY UPDATE대상 테이블의 기본 키 또는 고유 키를 기반으로 INSERT 또는 UPDATE를 수행합니다.가장 널리 알려져 있으며 단순하고 쉽게 구현할 수 있습니다.INSERT INTO tavle (col_id, col01, col02, col03, reg_date)VALUES ('A0001', 'val01', 'val02', 'val03'..

MySQL, Maria DB에서 컬럼 암, 복호화 하기얼마 전 운영 중인 서비스 상에서 이벤트를 위한 작은 프로젝트 하나를 담당할 기회가 있었습니다.프로젝트를 진행하던 중 Maria DB에서 자체적으로 제공하는 암, 복호화 기능을 사용하게 되어 정리해보고자 합니다. 암호화 알고리즘은 AES 대칭키 방식을 따르고 있습니다.따라서 암, 복호화에 사용되는 키를 꼭 준비해야 합니다.간단 함수 설명HEX : 숫자 또는 이진 문자열을 16진수로 변환함UNHEX : 16진수 문자열을 다시 숫자 또는 이진 문자열로 변환함AES_ENCRYPT : 문자열을 AES 알고리즘을 사용해 이진 문자열로 암호화함AES_DECRYPT : 이진 문자열을 평문으로 복호화함암호화하기아래와 같이 평문과 키를 이용해 암호화할 수 있습니다.아..

MySQL, Maria DB에서 날짜를 구하는 다양한 방법MySQL은 현재 날짜와 시간을 반환하는 다양한 함수를 제공합니다.대표적으로 SYSDATE()나 NOW() 함수가 있는데요, 이 외의 다양한 함수와 응용방법을 함께 알아보겠습니다.날짜와 시간 가져오기1. SYSDATE()날짜와 시간을 반환하는 가장 대표적인 함수입니다.함수가 호출되는 순간의 날짜와 시간을 반환합니다. 2. NOW()현재 날짜와 시간을 반환합니다.쿼리가 시작되는 순간의 날짜와 시간을 반환하기 때문에 SYSDATE()와 비교했을 때 약간의 오차가 존재합니다. 3. CURRENT_TIMESTAMP()NOW() 함수와 동일합니다. 4. LOCALTIME()NOW() 함수와 동일합니다. 5. LOCALTIMESTAMP()NOW() 함수와 동..

DATE_ADD와 DATE_SUB로 날짜 계산하기MySQL, Maria DB에서 주어진 날짜를 이용해 특정 기간의 전, 후를 계산하는 방법입니다.두 함수의 사용법은 사실상 동일한데 기본 문법은 아래와 같습니다.DATE_ADD(date, INTERVAL expr unit)DATE_SUB(date, INTERVAL expr unit)date : 기준이 되는 날짜expr : 더하거나 빼고 싶은 기간unit : 단위DATE_ADDDATE_ADD 함수는 주어진 날짜를 기준으로 특정 기간 이후를 계산하기 위한 함수입니다.DATE_ADD(date, INTERVAL expr unit)실제 예제를 보겠습니다.오늘 날짜를 기준으로 3개월 후의 날짜를 구해보겠습니다.SELECT DATE_ADD(NOW(), ..

My SQL 설치하기 Windows 10에 My SQL 설치하는 과정을 기록합니다. 1. My SQL 홈페이지 접속하기 https://www.mysql.com/downloads/ MySQL :: MySQL Downloads MySQL Cluster CGE MySQL Cluster is a real-time open source transactional database designed for fast, always-on access to data under high throughput conditions. MySQL Cluster MySQL Cluster Manager Plus, everything in MySQL Enterprise Edition Learn More » C www.mysql.com 스크롤..