일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- 판다스그래프
- 파이썬차트
- SQLSCOTT
- SQL
- SQL수업
- python알고리즘
- sql연습
- matplotlib
- 파이썬수업
- 데이터분석시각화
- sql연습하기
- 파이썬데이터분석
- 주피터노트북맷플롯립
- 주피터노트북데이터분석
- 파이썬
- Python
- 팀플기록
- 주피터노트북그래프
- python수업
- 파이썬데이터분석주피터노트북
- sql따라하기
- python데이터분석
- 파이썬크롤링
- 파이썬알고리즘
- 파이썬시각화
- 수업기록
- 주피터노트북
- 판다스데이터분석
- 주피터노트북판다스
- 맷플롯립
- Today
- Total
목록sql연습 (10)
IT_developers

hr 실습은 hr 생성 후 작성 가능. 문제를 다 푼 다음에 답 보기. hr의 데이터가 많기 때문에 각각의 칼럼명을 알고 있어야 문제를 풀 수 있다. 문제1) 매니저가 없는 사원들의 last_name, job_id 조회 문제2) ST_CLERK인 JOB_ID를 가진 사원이 없는 부서 id 조회(단, 부서번호가 null인 값은 제외) 문제3) commision_pct가 널이 아닌 사원들 중에서 commission = salart*commion_pct를 구하여, employee_id, first_name, job_id와 함께 출력 문제4) first_name이 Curtis인 사람의 first_name, last_name, phone_number,job_id 조회. (단,job_id의 결과는 소문자로 출력) ..

hr 실습은 hr 생성 후 작성 가능. 문제를 다 푼 다음에 답 보기. hr의 데이터가 많기 때문에 각각의 칼럼명을 알고 있어야 문제를 풀 수 있다. 문제1) employees 테이블 전체 내용 조회 문제2) employees 테이블의 first_name, last_name, job_id 조회 문제3) employees 테이블의 모든 열을 조회. 별칭 넣기 employee_id : empno , manager_id : mgr, department_id : deptno 조회 할 때 부서본호를 기준으로 내림차순으로 부서 번호가 같다면 사원 이름(First_name)을 기준으로 오름차순 정렬 문제4) 사원번호가 176인 사원의 last_name과 deptno 조회 문제5) 연봉이 12,000 이상 되는 직원들..

DML(데이터 조작어 : 삽입, 삭제, 수정) =>최종 반영을 할껀지 안할껀지 여부 ※ UPDATE : update 테이블 명 set 수정할 열 = 값 [where] ; where은 선택 1) loc를 seoul로 변경 UPDATE dept_temp SET loc = 'SEOUL'; where 사용 안함. ROLLBACK; 2) deptno=50인 경우 loc를 부산으로 변경 UPDATE dept_temp SET loc = 'BUSAN' WHERE deptno = 50; ROLLBACK; 3) EMP_TEMP 사원 중 SAL 3000이하인 사원만 COMM 300 으로 수정 UPDATE emp_temp SET comm = 300 WHERE sal

DML(데이터 조작어 : 삽입, 삭제, 수정) =>최종 반영을 할껀지 안할껀지 여부 1) DEPT 테이블의 데이터를 복사하여 dept_temp 테이블 생성. 실습용 테이블 생성 CREATE TABLE dept_temp AS SELECT * FROM dept; Ctrl + C => Ctrl + V 느낌 dept 조회를 해서 dept_temp 테이블을 생성하겠다. ※ insert(삽입) : insert into 테이블 명(열이름...) values(데이터...); 2) dept_temp에 deptno, dname, loc 값 넣기 INSERT INTO dept_temp ( deptno, dname, loc ) VALUES ( 50, 'DATABASE', 'SEOUL' ); 문자, 날짜 데이터는 ' 홑따옴표 ..

서브 쿼리 : 쿼리문 안에 또 다른 쿼리문 존재 select 조회할 열 from 테이블명 where 조건식(select 조회할 열 from 테이블 명 where 조건식) 실행결과가 하나로 나오는 단일행 서브쿼리 사용 연산자(>, 2975; ▶ 위 두개의 구문을 합한 것 SELECT * FROM emp WHERE sal > ( SELECT sal FROM emp WHERE ename = 'JONES' ); 여러개로 문장으로 구성되어 있는 것들을 하나로 만들어서 결과값을 출력 2) ALLEN 사원의 추가 수당보다 많은 추가수당을 받는 사원 정보 SELECT * FROM emp WHERE comm > ( SELECT comm FROM emp WHERE ename = 'ALLEN' ); 3) 'WARD' 보다 ..

다중행함수(여러개를 묶어서 한번에 해결) : SUM(), COUNT(), MAX(), MIN(), AVG() ※ SUM() : 합계 1) 추가수당 합계 : null은 카운트 되지 않음 SELECT SUM(comm) FROM emp; 2) 중복인 값은 제외하고 합계 구하기 SELECT SUM(DISTINCT sal), SUM(sal) FROM emp; ※ COUNT() : 숫자 세기 3) emp 테이블 사원 수 출력 SELECT COUNT(*) FROM emp; 전체적으로 구할 땐 * . * 대신 칼럼명 사용 가능 4) 부서번호가 30번인 사원 수 출력 SELECT COUNT(*) FROM emp WHERE deptno = 30; ※ MAX() : 최댓값, MIN() : 최솟값 5) 급여의 최대값 SELE..

형변환 함수(문자를 숫자로 변경 ) : TO_CHAR(), TO_NUMBER(), TO_DATE() 1) empno + '500' SELECT empno, ename, empno + '500' FROM emp WHERE ename = 'SMITH'; EMPNO == NUMBER, int 타입 알아서 연산을 해줌. 2) 'abcd' + empno SELECT empno, ename, 'abcd' + empno FROM emp WHERE ename = 'SMITH'; "invalid number" : abcd는 숫자로 변경 할 수 없기 때문에 오류 3) TO_CHAR() : 숫자, 날짜 데이터를 문자 데이터로 변환 SELECT to_char(sysdate, 'YYYY/MM/DD HH24:MI:SS') AS ..

숫자함수 : ROUND(), TRUNC(), CEIL(), FLOOR(), MOD() 날짜함수 : SYSDATE, CURRENT_DATE, CURRENT_TIMESTAMP 1) round() : 반올림 SELECT round(1234.5678) AS round, round(1234.5678, 0) AS round1, round(1234.5678, 1) AS round2, round(1234.5678, 2) AS round3, round(1234.5678, - 1) AS round4, round(1234.5678, - 2) AS round5 FROM dual; 자리를 지정하지 않으면 기본 값으로 출력. 기본값은 0 2) trunc() : 버림 SELECT trunc(1234.5678) AS trunc, t..