본문 바로가기
[MySQL] NULL 처리하기 MySQL에서는 NULL 값을 처리하기 위해 다양한 함수와 연산자를 제공합니다. NULL 값은 "unknown" 값을 의미하므로, 다른 값을 가지고 있는 열과 함께 연산되면 결과는 항상 NULL이 됩니다. 따라서 NULL 값을 적절하게 처리해야 합니다. 아래는 MySQL에서 NULL 값을 처리하는 방법에 대한 설명입니다. 1. IFNULL 함수 IFNULL 함수는 첫 번째 인수가 NULL인 경우 두 번째 인수로 대체합니다. 예를 들어, 아래의 쿼리는 name 열이 NULL인 경우 'Unknown'으로 대체합니다. SELECT IFNULL(name, 'Unknown') AS name FROM users; 2. COALESCE 함수 COALESCE 함수는 인수 중에서 NULL이 아닌 첫 번째 값을 반환합니다.. 2023. 3. 10.
[MySQL] 락 (lock) 확인 하고 해제 하는 방법 MySQL에서 락(lock)은 여러 클라이언트 사이에서 데이터의 일관성을 보장하기 위해 사용되는 메커니즘입니다. 락은 여러 클라이언트가 동시에 같은 데이터를 변경하려고 할 때, 각 클라이언트가 한 번에 하나의 작업만 수행하도록 합니다. 따라서, 락은 데이터 무결성을 보장하기 위한 매우 중요한 요소입니다. 1. 락(lock) 확인하기 SHOW OPEN TABLES 명령어를 사용하여 현재 열려있는 테이블 목록과 락 정보를 확인할 수 있습니다. SHOW OPEN TABLES WHERE In_Use > 0; SHOW PROCESSLIST 명령어를 사용하여 현재 실행 중인 쿼리 목록과 해당 쿼리가 락을 소유하고 있는지 여부를 확인 할 수 있습니다. SHOW PROCESSLIST; 명령어를 사용하여 InnoDB 엔.. 2023. 3. 10.
[MySQL] 조인 (Join) 정리 MySQL JOIN은 두 개 이상의 테이블에서 데이터를 가져와 결합하는 작업입니다. 이를 통해 데이터를 조합하고 쿼리 결과를 더욱 유용하게 만들 수 있습니다. MySQL JOIN은 크게 INNER JOIN, LEFT JOIN, RIGHT JOIN, FULL OUTER JOIN 등으로 분류됩니다. 1. INNER JOIN INNER JOIN은 두 개 이상의 테이블에서 매칭되는 데이터를 찾아서 결합하는 방식입니다. 예를 들어, 고객 정보와 주문 정보를 각각의 테이블에서 가져와 결합하는 경우, 두 테이블에서 공통으로 가지고 있는 고객 ID를 기준으로 INNER JOIN을 수행합니다. INNER JOIN은 공통된 값이 있는 경우에만 결과를 출력합니다. SELECT customers.name, orders.ord.. 2023. 3. 10.
[MySQL] 어제 날짜, 오늘 날짜, 내일 날짜 구하는 방법 MySQL에서 오늘, 어제, 내일 날짜를 구하는 방법은 다음과 같습니다. 1. 오늘 날짜 구하기 오늘 날짜는 NOW() 함수를 사용하여 구할 수 있습니다. NOW() 함수는 현재 시간을 반환합니다. 날짜만 필요한 경우 DATE() 함수로 형식을 변경할 수 있습니다. SELECT NOW(); # 2023-03-10 08:30:00 SELECT DATE(NOW()); # 2023-03-10 2. 어제 날짜 구하기 어제 날짜는 DATE_SUB() 함수를 사용하여 현재 날짜에서 1일을 뺀 값을 구합니다. DATE_SUB() 함수는 첫 번째 인수로 날짜를 받고, 두 번째 인수로 빼고자 하는 기간과 기간 단위를 받습니다. SELECT DATE_SUB(NOW(), INTERVAL 1 DAY); # 2023-03-09.. 2023. 3. 10.
[MySQL] 외래키 (foreign key) 적용 테이블 무시하고 삭제 만약 MySQL에서 DROP TABLE을 사용하여 외래 키가 있는 테이블을 삭제하려고 한다면, 다음과 같은 오류가 발생합니다. ERROR 1217 (23000): Cannot delete or update a parent row: a foreign key constraint fails 이 오류는 MySQL이 참조 무결성을 유지하기 위해 외래 키를 체크하고 있기 때문에 발생합니다. 외래 키가 있는 테이블을 삭제하려면 먼저 외래 키를 제거해야 합니다. 그렇지 않으면 위와 같은 오류가 발생합니다. 1. 해결 방법 MySQL에서 테이블을 삭제할 때 외래 키가 있는 경우 해당 키를 삭제하지 않으면 오류가 발생합니다. 외래 키를 무시하고 테이블을 삭제하려면 다음과 같은 단계를 따를 수 있습니다. SET FOREIG.. 2023. 3. 9.