일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- 패킷 필터
- Kali Linux
- 메일 프로토콜
- MSSQL
- 업무 자동화
- IMAP
- AutoHotkey
- Postman
- 모듈화
- Excel
- Eclipse
- JavaScript
- 인증서
- ES6
- SSMS
- VS Code
- mark/unmark
- kitri
- IPS
- Dreamhack
- power automate
- winmail.dat
- 포렌식
- 웹 크롤링
- wireshark
- db
- Log Parser
- coloring rules
- Revese Proxy
- server profiler
Archives
- Today
- Total
전산직으로 살아남기
MSSQL - 반복문 사용하기 본문
728x90
반응형
1. WHILE 사용하기
SQL에서는 WHILE 구문을 통해 반복문을 사용할 수 있습니다. 반복문은 { } 블록이 아닌 BEGIN ~ END 블록으로 구성됩니다.
DECLARE @num INT
SET @num = 10
WHILE @num > 0 -- 조건 입력
BEGIN
SET @num = @num - 1
print @num
END
참고로 루프에 영향을 주는 구문은 다음과 같습니다.
- CONTINUE : 바로 WHILE문으로 이동
- BREAK : WHILE 루프를 종료한다. 루프의 끝을 표시하는 END 키워드 다음에 있는 쿼리문 실행
- RETURN : 현재 처리되는 것을 무조건 종료하고 호출자에게 값을 반환
2. CURSOR 사용하기
CURSOR는 SQL에서 행 단위 작업을 효율적으로 하기 위한 방식으로 테이블에서 여려 개의 행을 조회한 후 쿼리의 결과를 한 행씩 처리하는 방식입니다. SELECT 한 결과를 반복 작업하여 처리할 경우에는 유용하지만 많은 양의 데이터를 처리할 때는 SQL의 성능을 떨어트리기에 주의해야 됩니다.
--변수 선언 조회한 컬럼을 담을 변수도 선언해야한다.
DECLARE
@INDEX INT,
@NAME VARCHAR(100),
@AGE INT
SET @INDEX = 0; --INDEX초기화
DECLARE CUR CURSOR FOR --CUR라는 이름의 커서 선언
SELECT --쿼리 조회
NAME,
AGE
FROM MY_FRIEND
OPEN CUR --커서 오픈
FETCH NEXT FROM CUR INTO @NAME,@AGE --SELECT한 값을 @NAME,@AGE 변수에 넣는다.
--커서를이용해 한ROW씩 읽음
WHILE @@FETCH_STATUS = 0
BEGIN
SET @INDEX = @INDEX + 1; --INDEX증가
--SELECT 한 데이터의 행집합을 가지고 수행할 작업
UPDATE MY_FRIEND
SET AGE = @AGE+1 --나이+1
WHERE NAME = @NAME
FETCH NEXT FROM CUR INTO @NAME,@AGE --다음ROW로 이동
END
--커서 닫고 초기화
CLOSE CUR
DEALLOCATE CUR
🗒️ CURSOR는 어느 경우에 사용할까요?
만약에 급여 계산로직을 쿼리문으로 구축했다고 가정했을 때 인원마다 처리되는 급여 프로세스가 분명 다를 것입니다. 이때 CURSOR를 이용하여 해당 인원마다 급여처리를 할 수 있습니다. 실제로 CURSOR는 이와 비슷한 로직들에서 많이 사용되고 있습니다.
728x90
반응형
'Development > MSSQL' 카테고리의 다른 글
MSSQL - Server Profiler (0) | 2024.05.17 |
---|---|
MSSQL - Stored Procedure (0) | 2024.05.16 |
MSSQL - 조건문 사용하기 (0) | 2024.05.08 |
MSSQL - 변수 활용하기 (0) | 2024.05.07 |
MSSQL - Table 제어하기 (0) | 2024.04.30 |