Web Back-End/MySQL
MySQL 학습 02 - IFNULL, union, TRUNCATE
hyg4196
2021. 5. 21. 11:35
반응형
1. IFNULL( 'TRUE', 'FALSE')
참일시 앞부분, 거짓일시 뒷부분이 출력.
2. union
여러 검색문을 묶어 검색내용을 한번에 처리
- 유니온의 규칙
1. 하나의 ORDER BY만 사용할 수 있다.
2. 각 SELECT의 열수, 표현식가 같아야 한다.
3. SELECT 문들 끼리 순서는 상관없다.
4. 유니온을 한 결과가 중복되면 하나만 나온다. (DEFAULT)
5. 열의 타입은 같거나 반환 가능한 형태여야 한다.
6. 중복값을 나타내고 싶다면 UNION ALL
3. TRUNCATE artcile;
article 테이블의 모든 내용을 지운다
# a6 DB 삭제/생성/선택
CREATE DATABASE `a6`;
DROP DATABASE IF EXISTS `a6`;
USE `a6`;
# 부서(홍보, 기획, IT)
CREATE TABLE dept(
id INT(100) UNSIGNED AUTO_INCREMENT PRIMARY KEY,
NAME VARCHAR(100) NOT NULL,
regDate DATETIME NOT NULL
);
DROP TABLE dept;
INSERT INTO dept SET NAME ='홍보', regDate =NOW();
INSERT INTO dept SET NAME ='기획', regDate =NOW();
INSERT INTO dept SET NAME ='IT', regDate =NOW();
SELECT * FROM dept;
# 사원(홍길동/홍보/5000만원, 홍길순/홍보/6000만원, 임꺽정/기획/4000만원)
## IT부서는 아직 사원이 없음
CREATE TABLE emp(
id INT(100) UNSIGNED AUTO_INCREMENT PRIMARY KEY,
NAME VARCHAR(100) NOT NULL,
regDate DATETIME NOT NULL,
salary INT(200) NOT NULL,
deptId INT(100) NOT NULL
);
DESC emp;
DROP TABLE emp;
INSERT INTO emp SET NAME ='홍길동', regDate =NOW(), salary = 50000000, deptId = 1;
INSERT INTO emp SET NAME ='홍길순', regDate =NOW(), salary = 60000000, deptId = 1;
INSERT INTO emp SET NAME ='임꺽정', regDate =NOW(), salary = 4000000, deptId = 2;
SELECT * FROM emp;
# 전 사원에 대하여, [부서명, 사원번호, 사원명] 양식으로 출력
SELECT D.name AS '부서명',E.id AS '사원번호' ,E.name AS '사원번호' FROM emp AS E JOIN dept AS D ON E.deptId = D.id;
# 전 사원에 대하여, [부서명, 사원번호, 사원명] 양식으로 출력
## IT부서는 [IT, NULL, NULL] 으로 출력
SELECT D.name AS '부서명',E.id AS '사원번호' ,E.name AS '사원번호' FROM emp AS E RIGHT JOIN dept AS D ON E.deptId = D.id;
# 전 사원에 대하여, [부서명, 사원번호, 사원명] 양식으로 출력
## IT부서는 [IT, 0, -] 으로 출력
SELECT D.name AS '부서명',IFNULL(E.id,0) AS '사원번호' ,IFNULL(E.name,' -') AS '사원번호' FROM emp AS E RIGHT JOIN dept AS D ON E.deptId = D.id;
SELECT * FROM emp;
# 모든 부서별, 최고연봉, IT부서는 0원으로 표시
SELECT D.name AS '부서명',IFNULL(MAX(E.salary), 0) AS '최고연봉' FROM emp AS E RIGHT JOIN dept AS D ON E.deptId = D.id GROUP BY D.id;
# 모든 부서별, 최저연봉, IT부서는 0원으로 표시
SELECT D.name AS '부서명',IFNULL(MIN(E.salary), 0) AS '최고연봉' FROM emp AS E RIGHT JOIN dept AS D ON E.deptId = D.id GROUP BY D.id;
# 모든 부서별, 평균연봉, IT부서는 0원으로 표시
SELECT D.name AS '부서명',IFNULL(AVG(E.salary), 0) AS '최고연봉' FROM emp AS E RIGHT JOIN dept AS D ON E.deptId = D.id GROUP BY D.id;
# 하나의 쿼리로 최고액연봉자와 최저역연봉자의 이름과 연봉
SELECT NAME, MAX(salary) FROM emp;
SELECT MIN(salary) FROM emp;
SELECT E.* FROM (SELECT MIN(salary) FROM emp) E, dept;
SELECT emp.name AS '이름', emp.salary AS '연봉' FROM (SELECT MIN(salary) AS 'min' FROM emp) E,
(SELECT NAME, MAX(salary) AS 'max' FROM emp) AS D,
emp
WHERE salary = E.min OR salary = D.max;
반응형