sqldeveloper(28)
-
Day36 - Quiz를 풀어 봅시다
문제 1. employees테이블, departments테이블을 left조인 hire_date를 오름차순 기준으로 1-10번째 데이터만 출력합니다 조건) rownum을 적용하여 번호, 직원아이디, 이름, 전화번호, 입사일, 부서아이디, 부서이름 을 출력합니다. 조건) hire_date를 기준으로 오름차순 정렬 되어야 합니다. rownum이 틀어지면 안됩니다. - 쌤 답. 문제 2. -EMPLOYEES 과 DEPARTMENTS 테이블에서 JOB_ID가 SA_MAN 사원의 정보의 LAST_NAME, JOB_ID, DEPARTMENT_ID,DEPARTMENT_NAME을 출력하세요 - 쌤 답 문제 3. -DEPARTMENT테이블에서 각 부서의 ID, NAME, MANAGER_ID와 부서에 속한 인원수를 출력하세..
2021.04.06 -
Day36 - 행수정.UPDATE , 행삭제.DELETE
이번에는 UPDATE 와 DELETE 를 알아 봅시다. UPDATE 와 DELETE 는 데이터를 수정, 삭제 하는 것이기 때문에 아주 조심히 사용해야 합니다. 그렇기 때문에, 항상 사용 전 먼저 SELECT를 해봐야 합니다. UPDATE UPDATE는 데이터를 수정하는 것을 의미합니다. UPDATE를 확인 하기 위해서, 테이블을 복사 해봅시다. - UPDATE 테이블명 SET 속성 = 값 WHERE 조건 항상 UPDATE를 하기 전, SELECT를 사용해 원하는 행이 맞는지 확인을 해줍니다. 값을 변경해 줄 행이 맞다면, UPDATE를 사용해서 값을 변경 해주면 됩니다. WHERE절의 조건에는 보통 기본키(PK)를 기준으로 합니다. ※ SET절에 여러개의 속성들을 사용해 값을 변경할 수 있습니다. - W..
2021.04.06 -
Day36 - 행추가.INSERT , 테이블 복사.CTAS , 복구.ROLLBACK
이번에는 INSERT 에 대해서 알아 봅시다. 그 전에, 잠깐 테이블의 구조를 확인하는 방법을 알아보고 갑시다. DESC 테이블명 이렇게, 해당 테이블에 속성(column)들과 널(공백)을 포함할 것인지 여부. 그리고 값의 유형은 어떤식으로 할 것인지 확인 할 수 있습니다. NUMBER는 숫자를 의미 하며 소괄호에 있는 숫자는 자리수를 의미합니다. (4자리) VARCHAR2는 가변성문자를 의미 하며, 소괄호에 있는 숫자는 BYTE를 의미합니다. INSERT insert 는 테이블에 행을 추가하는 기능 입니다. - INSERT INTO 테이블명(속성) VALUES(값) INSERT INTO 를 사용할 때, 테이블의 속성을 넣어주면 되는데, 테이블의 속성을 전부 넣어줄 필요는 없습니다. 만약, 테이블의 속성..
2021.04.06 -
Day35 - Quiz를 풀어 봅시다
문제 1. -EMPLOYEES 테이블에서 모든 사원들의 평균급여보다 높은 사원들을 데이터를 출력 하세요 ( AVG(컬럼) 사용) -EMPLOYEES 테이블에서 모든 사원들의 평균급여보다 높은 사원들의 수를 출력하세요 -EMPLOYEES 테이블에서 job_id가 IT_PFOG인 사원들의 평균급여보다 높은 사원들을 데이터를 출력하세요 문제 2. -DEPARTMENTS테이블에서 manager_id가 100인 사람의 department_id와 EMPLOYEES테이블에서 department_id가 일치하는 모든 사원의 정보를 검색하세요. 문제 3. -EMPLOYEES테이블에서 “Pat”의 manager_id보다 높은 manager_id를 갖는 모든 사원의 데이터를 출력하세요 -EMPLOYEES테이블에서 “Jame..
2021.04.05 -
Day35 - 인라인 뷰
이번에는 인라인 뷰에 대해서 알아 봅시다 인라인 뷰 인라인 뷰도 서브쿼리의 한 종류 입니다. 인라인 뷰는 FROM 옆에 위치 합니다. ( 테이블 이름 대신 ) 인라인 뷰는 가상의 테이블 이라고 생각하면 됩니다. 인라인 뷰 에서 조회되는 속성(column)들이 테이블(엔티티) 대신해서 들어간다고 생각하면 되겠습니다. 위의 기본 형태를 아래의 인라인 뷰의 형태로 바꿈 - rownum ( 행 번호 ) 가 섞이는 문제 정렬과 rownum 을 같이 사용하면, rownum의 번호가 뒤죽박죽이 됩니다. 이 문제를, 인라인 뷰를 사용해서 해결 할 수 있는데요, 인라인 뷰의 내부에서 정렬을 한 후, 바깥 쪽에서 rownum을 사용해주면 됩니다. - 행을 제한해서 조회하기. rownum을 사용해서 행을 줄여서 조회할 수 ..
2021.04.05 -
Day35 - 스칼라 서브쿼리
이번에는 스칼라 서브쿼리에 대해서 알아 봅시다. 스칼라 서브쿼리 저번 시간에 알아 보았던, "단일 행 서브쿼리 / 다중 행 서브쿼리" 는 WHERE 옆에 위치 했었죠? 스칼라 서브쿼리는 SELECT 옆에 위치 합니다. 스칼라 서브쿼리는 LEFT OUTER JOIN 과 결과값이 똑같습니다. 하지만, JOIN 하는 것보다 성능이 우수합니다. 그 이유는, JOIN은 테이블을 전부 읽어서 데이터를 가져오지만, 스칼라 서브쿼리는 테이블의 필요한 부분만 읽어서 데이터를 가져오기 때문입니다. 그러면, 어떻게 사용하는지 한 번 알아 봅시다. ※스칼라 쿼리를 사용할 경우에 *를 사용한다면, 어떤 테이블의 정보인지를 명시해 주셔야 합니다. 스칼라 서브쿼리 뿐 아니라, 서브쿼리를 사용할 때는 () 안에 사용해 주셔야 합니다..
2021.04.05