일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
29 | 30 | 31 |
Tags
- 콜렉션
- 싱글턴
- wrapper
- start.spring.io
- 자동형변환
- 내장객체
- 클래스
- 컬렉션
- 제너릭
- Jenkins
- 루프
- 스프링
- 인텔리제이
- Short
- 무한
- dependency
- suvlet
- 싱글톤
- 메소드
- 언박싱
- unboxing
- Java
- boxing
- Scanner
- bootstrap
- maven
- 박싱
- https://start.spring.io
- 제네릭
- 빌드
Archives
- Today
- Total
Developer Gonie
[6주차] 28. PL/SQL언어, SELECT into from쿼리(결과가 1개 행만 나오는 쿼리에서 값을 가져올 수 있음) 본문
K-DigitalTraining 강의/2. Oracle + PLSQL
[6주차] 28. PL/SQL언어, SELECT into from쿼리(결과가 1개 행만 나오는 쿼리에서 값을 가져올 수 있음)
이대곤 2022. 6. 16. 16:50* 주의, select ~ into구문은 쿼리문의 결과가 1줄만 나오는 경우에만 사용이 가능하다.
* PL/SQL 에서는 한 번에 모두를 읽어오는 기능은 없고, 한 줄 씩만 읽어오는게 가능하다.
* 조회된 결과를 받아올 변수는 컬럼의 타입과 일치해야 한다.
기본예제
--바로 아래의 쿼리문의 결과에서 값을 가져오는 방법이다.
select name, position, salary
from company
where sabun=3;
NAME POSITION SALARY
------------------------ -------------------- ----------
찬열 과장 3000
-------------------------------------------------------
declare
vname varchar2(12); -- 타입은 가져온 값과 일치해야 한다.
vposition varchar2(12); -- 타입은 가져온 값과 일치해야 한다.
vsalary number; -- 타입은 가져온 값과 일치해야 한다.
begin
select name, position, salary -- 테이블에서 조회할 컬럼 선택
into vname, vposition, vsalary -- 조회된 결과를 받아올 변수
from company
where sabun=3;
dbms_output.put_line(vname || ',' || vposition || ',' || vsalary);
end;
/
찬열,과장,3000
PL/SQL 처리가 정상적으로 완료되었습니다.
--바로 아래의 쿼리문의 결과에서 값을 가져오는 방법이다.
select max(salary), avg(salary)
from company;
MAX(SALARY) AVG(SALARY)
----------- -----------
9000 4500
-------------------------------------------------------
declare
vsalary number;
vavg number;
begin
select max(salary), avg(salary)
into vsalary, vavg
from company;
dbms_output.put_line('최고급여: ' || vsalary);
dbms_output.put_line('평균급여: ' || vavg);
end;
/
최고급여: 9000
평균급여: 4500
PL/SQL 처리가 정상적으로 완료되었습니다.
--바로 아래의 쿼리문의 결과에서 값을 가져오는 방법이다.
select depart, avg(salary)
from members
group by depart
having avg(salary) >= 2000;
DEPART AVG(SALARY)
-------------------- -----------
홍보부 500100
-------------------------------------------------------
declare
mdepart varchar(20);
msalary number;
begin
select depart, avg(salary)
into mdepart, msalary
from members
group by depart
having avg(salary) >= 2000;
dbms_output.put_line('부서: ' || msalary );
dbms_output.put_line('평균: ' || msalary );
end;
/
부서: 500100
평균: 500100
PL/SQL 처리가 정상적으로 완료되었습니다.
좀더 편리함을 높일 수 있는 예제
[6주차] 33. PL/SQL언어, 변수의 타입을 간편하게 지정하는 방법, 1줄의 레코드를 한 번에 다 담을 수 있는 타입
'K-DigitalTraining 강의 > 2. Oracle + PLSQL' 카테고리의 다른 글
[6주차] 30. PL/SQL언어, if문 작성하는 방법 (0) | 2022.06.16 |
---|---|
[6주차] 29. PL/SQL언어, INSERT, UPDATE, DELETE 쿼리 사용방법 (0) | 2022.06.16 |
[6주차] 27. PL/SQL언어, 사용전 기초 지식 (0) | 2022.06.16 |
[6주차] 26. 부모 테이블이 존재하도록 특정 필드를 foreign key(=자식키)로 지정하는 방법*** (0) | 2022.06.16 |
[6주차] 25. 상위 N개의 데이터를 추출하는 Top N 쿼리(Inline View, 특수컬럼)*** (0) | 2022.06.15 |
Comments