방법1SELECT EMP_ID,EMP_NAME,SALARY FROM EMPLOYEE;
방법2SELECT EMP_ID,EMP_NAME, SALARY
FROM EMPLOYEE;
SELECT 컬럼명 -- 조회하고자 하는 컬럼명 기술 FROM 테이블명 -- 조회하고자 하는 컬림이 포함된 테이블명 기술 WHERE 조건식; -- 행을 선택하는 조건 기술, 조건을 만족하는 행만 반환 -- 조건식 복수로 붙여서 사용가능. 복수라도 WHERE절 한개만 기술
한 테이블의 모든 정보 조회
--EMPLOYEE 테이블의 모든 정보 조회
방법1SELECT EMP_ID,EMP_NAME, EMP_NO, EMAIL, PHONE, DEPT_CODE, JOB_CODE, SAL_LEVEL, SALARY,
BONUS, MANAGER_ID, HIRE_DATE, ENT_DATE, ENT_YN FROM EMPLOYEE ;
방법2SELECT*-- * : 전체FROM EMPLOYEE;
DISTINCT
중복제거
DISTINCT는 한번만 쓸 수 있다
-- DISTINCT : 중복제거SELECTDISTINCT JOB_CODE
FROM EMPLOYEE;
-- EMPLOYEE 테이블에서 직원의 부서 코드를 중복 없이 조회SELECTDISTINCT DEPT_CODE
FROM EMPLOYEE;
-- DISTINCT는 한번만 쓸 수 있다--SELECT DISTINCT DEPT_CODE, DISTINCT DEPT_CODE -- ERROR--FROM EMPLOYEE;
DISTINCT A,B 콤마로 같이 쓰면 ()로 묶은 효과 발생
콤마로 두 컬럼을 묶으면 두 컬럼의 조건이
AND조건으로 교집합 된 것만 중복 제거한다
SELECTDISTINCT DEPT_CODE, JOB_CODE -- 콤마로 두 컬럼을 묶으면 두 컬럼의 조건이 FROM EMPLOYEE; -- AND조건으로 교집합 된 것만 중복 제거한다
리터럴(literal)
값 자체
싱글쿼테이션( ' ' )
오라클에서는 문자,문자열,데이트 상관없이 다 싱글쿼테이션(’ ‘)으로 감싸준다
컬럼 별칭
컬럼명 AS 별칭 / 컬럼명 AS “별칭” / 컬럼명 별칭 / 컬럼명 “별칭”
별칭 : ""
쌍따옴표( “”)를 무조건 붙여야하는 조건
1)별칭에 특수문자가 들어갈 경우 2)별칭이 숫자로 시작할 경우 쌍따옴표 = 더블 쿼테이션(” ”) EX) 직원 명 ←띄어쓰기 공백 특수문자라 “직원 명”으로 적어줘야한다 EX) SALARY*12 AS 연봉
-- ESCAPE 식별자-- EMPLOYEE테이블에서 김씨 성이 아닌 직원의 사번, 이름, 고용일 조회SELECT EMP_ID, EMP_NAME, HIRE_DATE
FROM EMPLOYEE
--WHERE EMP_NAME NOT LIKE '김%';WHERENOT EMP_NAME LIKE'김%';
--WHERE NOT EMP_NAME LIKE '김%';-- NOT 순서 : 해당 컬럼명 앞뒤 둘 다 가능/*
WHERE EMP_NAME != '김%';
= 혹은 != '김%'으로 검색하면 '김%' 데이터자체를 검색
LIKE '김%' 뒤에 어떤게 오든 상관없다
LIKE와 사용하는 % _ 는 와일드카드 적용받는다
LIKE는 문자에 대한 패턴 검색하는 것
!= '김%'에서는 이름이 김%인 사람을 찾는 것(리터럴 김% 데이터를 찾는 것)
여기서 %는 와일드카드로 적용이 되지 않고 그냥 순수 기호 %인 것
*/-----------실습문제-------------1.EMPLOYEE 테이블에서 이름 끝이 '연'으로 끝나는 사원 이름 조회--2.EMPLOYEE 테이블에서 전화번호 처음 세자리가 010이 아닌 사원의 이름, 전화번호 조회--3.EMPLOYEE 테이블에서 메일주소 _의 앞이 4자이면서 DEPT_CODE가 D9 또는 D6이고-- 고용일이 90/01/01 ~ 00/12/01이고, 급여가 2700000만 이상인 사원의 전체 정보 조회SELECT EMP_NAME
FROM EMPLOYEE
WHERE EMP_NAME LIKE'%연';
SELECT EMP_NAME, PHONE
FROM EMPLOYEE
WHERE PHONE NOTLIKE'010%';
SELECT*FROM EMPLOYEE
WHERE EMAIL LIKE'____!_%'ESCAPE'!'AND (DEPT_CODE ='D9'OR DEPT_CODE ='D6')
-- AND (HIRE_DATE >= '90/01/01' AND HIRE_DATE <= '00/12/01')AND HIRE_DATE BETWEEN'90/01/01'AND'00/12/01'AND SALARY >=2700000;
-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- IS NULL-- IS NOT NULL-- 컬럼값이 NULL이냐-- 컬럼값이 NULL이 아니냐--EMPLOYEE 테이블에서 보너스를 받지 않는 사원의 사번, 이름, 급여, 보너스 조회SELECT EMP_ID, EMP_NAME,SALARY,BONUS
FROM EMPLOYEE
WHERE BONUS ISNULL;
--WHERE BONUS = NULL; 값 안나옴--WHERE BONUS = (null); 값 안나옴--EMPLOYEE 테이블에서 보너스를 받는 사원의 사번, 이름, 급여, 보너스 조회SELECT EMP_ID, EMP_NAME,SALARY,BONUS
FROM EMPLOYEE
WHERE BONUS ISNOTNULL;
WHERENOT BONUS ISNULL;
-- WHERE NOT BONUS IS NULL; -- NOT은 컬렴명 앞에 붙어도 가능--WHERE BONUS NOT LIKE '%(null)%';-- EMPLOYEE 테이블에서 관리자도 없고 부서 배치도 받지 않은 직원의 이름, 관리자, 부서코드 조회-- EMPLOYEE 테이블에서 부서 배치를 받지 않았지만 보너스를 지급받는 직원의 이름, 보너스, 부서코드 조회SELECT EMP_NAME, MANAGER_ID, DEPT_CODE
FROM EMPLOYEE
WHERE MANAGER_ID ISNULLAND DEPT_CODE ISNULL;
SELECT EMP_NAME, BONUS, DEPT_CODE
FROM EMPLOYEE
WHERE DEPT_CODE ISNULLAND BONUS ISNOTNULL;
--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------IN-- 목록에 일치하는 값이 있으면 TRUE가 되어 값 반환-- 목록에 일치하는 값이 있으면 TRUE를 반환-- D6부서와 D9부서원들의 이름, 부서코드, 급여 조회-- 직급코드가 J1, J2, J3, J4인 사람들의 이름, 직급코드, 급여 조회SELECT EMP_NAME, DEPT_CODE, SALARY
FROM EMPLOYEE
WHERE DEPT_CODE ='D6'OR DEPT_CODE ='D9';
SELECT EMP_NAME, JOB_CODE, SALARY
FROM EMPLOYEE
--WHERE JOB_CODE = 'J1' OR JOB_CODE = 'J2' OR JOB_CODE = 'J3' OR JOB_CODE = 'J4';WHERE JOB_CODE IN ('J1','J2','J3','J4');
-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- 연결 연산자 ||-- 자바에서의 or논리연산자의 기호가 SQL에서는 연결연산자-- EMPLOYEE테이블에서 사번, 이름, 급여를 연결해서 조회 (EX. 200선동일8000000)SELECT EMP_ID || EMP_NAME || SALARY
FROM EMPLOYEE;
SELECT EMP_ID || EMP_NAME || SALARY 전체결과
FROM EMPLOYEE;
-- EMPLOYEE테이블에서 ' "사원명"의 월급은 "급여"원입니다' 형식으로 조회SELECT EMP_NAME ||'의 월급은'|| SALARY||'원입니다'FROM EMPLOYEE;
-- EMPLOYEE 테이블에서 부서코드가 D6이고 급여를 3000000보다 많이 받는 직원의 이름, 부서코드, 급여 조회SELECT EMP_NAME, DEPT_CODE, SALARY
FROM EMPLOYEE
WHERE DEPT_CODE ='D6'AND SALARY >3000000;
-- EMPLOYEE 테이블에서 부섴드가 D6이거나 급여를 3000000보다 많이 받는 직원의 이름,부서코드, 급여조회SELECT EMP_NAME, DEPT_CODE, SALARY
FROM EMPLOYEE
WHERE DEPT_CODE ='D6'OR SALARY >3000000;
OR AND 연산 우선순위
자바나 SQL이나 OR AND 연산순서는 AND가 우선순위로 먼저 연산
OR를 먼저 연산하고 싶다면 소괄호를 쳐줄 것
BETWEEN
~이상 ~이하
-- EMPLOYEE 테이블에서 급여를 3500000이상 6000000이하를 받는 사원의 사번, 이름, 급여, 부서코드, 직급코드 조회SELECT EMP_ID, EMP_NAME, SALARY, DEPT_CODE, JOB_CODE
FROM EMPLOYEE
WHERE SALARY BETWEEN3500000AND6000000;
초과 미만은?
not between
-- 반대로 급여를 3500000미만 6000000초과를 받는 사원의 사번, 이름, 급여, 부서코드, 직급코드 조회SELECT EMP_ID, EMP_NAME, SALARY, DEPT_CODE, JOB_CODE
FROM EMPLOYEE
-- WHERE SALARY < 3500000 OR SALARY > 6000000;WHERE SALARY NOTBETWEEN3500000AND6000000;
WHERENOT SALARY BETWEEN3500000AND6000000;
-- NOT 위치 둘 다 가능
LIKE
비교하려는 값이 특정 패턴을 만족시키는지 조회
ex) 이멜에 i가 들어가는 것을 조회, 이름이 김씨가 들어간 사람들 조회
--EMPLOYEE 테이블에서 이름이 '하'가 포함된 직원의 이름, 주민번호, 부서코드 조회SELECT EMP_NAME, EMP_NO, DEPT_CODE
FROM EMPLOYEE
WHERE EMP_NAME LIKE'%하%';
와일드카드 2종류 : _ %
_ : 1글자 % : 0글자 이상
ex) '' (한글자) '__'(두글자) ***'__***' (세글자)
'글자%' : 글자로 시작하는 값
글자 뒤로 뭐가와도 ok
ex) 글자최고, 글자(공백), 글자왕, 글자
'%글자' : 글자로 끝나는 값
글자 앞에 뭐가와도 ok
ex) 먹글자, 한글은 글자, (공백)글자
'글%자' : 글로 시작해서 자로 끝나는 값
글과 자 사이 뭐가와도 ok
ex)글씨를 잘쓰자, 글자, 글과자, 글(공백)자
'%글자%' : 글자가 포함되어있는 값
ex) 한글자값, 먹글자, 글자, 한두글자
-- 논리 연산자 AND OR-- EMPLOYEE 테이블에서 부서코드가 D6이고 급여를 3000000보다 많이 받는 직원의 이름, 부서코드, 급여 조회SELECT EMP_NAME, DEPT_CODE,SALARY
FROM EMPLOYEE
WHERE DEPT_CODE ='D6'AND SALARY >3000000;
-- EMPLOYEE 테이블에서 부섴드가 D6이거나 급여를 3000000보다 많이 받는 직원의 이름,부서코드, 급여조회SELECT EMP_NAME, DEPT_CODE,SALARY
FROM EMPLOYEE
WHERE DEPT_CODE ='D6'OR SALARY >3000000;
-- 1.EMPLOYEE 테이블에서 월급이 4000000이상이고 JOB_CODE가 J2인 사원의 전체 내용 조회-- 2.EMPLOYEE 테이블에 DEPT_CODE가 D9이거나 D5인 사원 중에 고용일이 02년 1월 1일보다 빠른 사원의-- 이름, 부서코드, 고용일 조회SELECT*FROM EMPLOYEE
WHERE SALARY >=4000000AND JOB_CODE ='J2';
SELECT EMP_NAME, DEPT_CODE, HIRE_DATE
FROM EMPLOYEE
WHERE DEPT_CODE ='D9'OR HIRE_DATE <'02/01/01';
-- 이 코드는 틀린 코드-- 기준일보다 작은게 빠른 것. 오늘보다 내일이 더 큰 숫자-- 날짜를 기준으로 조건식을 쓴다면 ''로 감싸줘야한다-- 자바나 SQL이나 OR AND는 AND가 우선순위로 먼저 연산-- OR를 먼저 연산하고 싶다면 소괄호를 쳐줄 것-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- BETWEEN AND-- ~이상 ~이하-- EMPLOYEE 테이블에서 급여를 3500000이상 6000000이하를 받는 사원의 사번, 이름, 급여, 부서코드, 직급코드 조회SELECT EMP_ID, EMP_NAME, SALARY, DEPT_CODE, JOB_CODE
FROM EMPLOYEE
WHERE SALARY >=3500000AND SALARY <=6000000;
SELECT EMP_ID, EMP_NAME, SALARY, DEPT_CODE, JOB_CODE
FROM EMPLOYEE
WHERE SALARY BETWEEN3500000AND6000000;
-- 반대로 급여를 3500000미만 6000000초과를 받는 사원의 사번, 이름, 급여, 부서코드, 직급코드 조회SELECT EMP_ID, EMP_NAME, SALARY, DEPT_CODE, JOB_CODE
FROM EMPLOYEE
--WHERE SALARY < 3500000 OR SALARY > 6000000; --WHERE SALARY NOT BETWEEN 3500000 AND 6000000;WHERENOT SALARY BETWEEN3500000AND6000000;
-------실습문제--------- 1.EMPLOYEE 테이블에 고용일이 90/01/01 ~ 01/01/01인 사원의 전체 내용을 조회-- 시간의축을 가로선상에 놓고 보면 시간과 연산자 사용계산이 쉬워짐SELECT*FROM EMPLOYEE
WHERE HIRE_DATE >='90/01/01'AND HIRE_DATE <='01/01/01';
SELECT*FROM EMPLOYEE
WHERE HIRE_DATE BETWEEN'90/01/01'AND'01/01/01';
-- WHERE HIRE_DATE >= '90/01/01' AND HIRE_DATE <= '01/01/01';------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------/*
-- LIKE
비교하려는 값이 특정 패턴을 만족시키는지 조회
ex) 이멜에 i가 들어가는 것을 조회, 이름이 김씨가 들어간 사람들 조회
와일드카드 2종류
_ : 1글자
% : 0글자 이상
ex)
'_' (한글자)
'__' (두글자)
'___' (세글자)
'글자%' : 글자로 시작하는 값
글자 뒤로 뭐가와도 ok
ex) 글자최고, 글자(공백), 글자왕, 글자
'%글자' : 글자로 끝나는 값
글자 앞에 뭐가와도 ok
ex) 먹글자, 한글은 글자, (공백)글자
'글%자' : 글로 시작해서 자로 끝나는 값
글과 자 사이 뭐가와도 ok
ex)글씨를 잘쓰자, 글자, 글과자, 글(공백)자
'%글자%' : 글자가 포함되어있는 값
ex) 한글자값, 먹글자, 글자, 한두글자
*/--EMPLOYEE 테이블에서 성이 전씨인 사원의 사번, 이름, 고용일 조회SELECT EMP_ID, EMP_NAME, HIRE_DATE
FROM EMPLOYEE
WHERE EMP_NAME LIKE'전%';
-- WHERE EMP_NAME LIKE '전__';-- 도 가능하나 이름이 세글자인 사람들만 가능해서 이름이 두글자나 네글자이상이면 정확도가 떨어짐--EMPLOYEE 테이블에서 이름이 '하'가 포함된 직원의 이름, 주민번호, 부서코드 조회SELECT EMP_NAME, EMP_NO, DEPT_CODE
FROM EMPLOYEE
WHERE EMP_NAME LIKE'%하%';
--EMPLOYEE 테이블에 전화번호 4번째 자리가 9로 시작하는 사원의 사번, 이름, 전화번호 조회-- 전번 양식 : 01012345678-- 01X 세자리 + 9로 시작하는 네번지째 자릿수SELECT EMP_ID, EMP_NAME, PHONE
FROM EMPLOYEE
WHERE PHONE LIKE'___9%';
--EMPLOYEE 테이블에서 이메일 중 _의 앞 글자가 3자리인 이메일 주소를 가진 사원의 사번의 사번, 이름, 이메일 주소 조회SELECT EMP_ID, EMP_NAME, EMAIL
FROM EMPLOYEE
WHERE EMAIL LIKE'___ _%'ESCAPE' ';
D
--WHERE EMAIL LIKE '___%'; -- 언더바_가 들어간 이메일 출력. 앞글자 2개도 4개 전부 출력-- ESCAPE의 기준이 되는 코드는 ' '안에서 설정 가능? YES-- ESCAPE의 ' '안에 어떤 코드이던 들어가서 설정 가능?/*
LIKE를 쓸 때 패턴!
와일드카드 : _ %
각각 한글자,와 0글자 이상을 나타내는 와일드 카드
세글자 자릿수 언더바 3개 + 검색하고자 하는 데이터로의 언더바 1개 = 총4개의 언더바
검색하고자 하는 패턴의 문자와 와일드 카드가 일치할 경우에는 패턴과 와일드 카드를 구분하지 못하기 때문에
ESCAPE OPTION을 통해 구분해준다
- 패턴(데이터)으로 쓸 것 앞에 구분기호 사용
*/