PL/SQL'de Koşul Kontrolü Nasıl Yapılır? IF, LOOP, WHILE , GOTO Kullanımı
pl sql goto kullanımı
,
pl sql karışık if kullanımı
,
pl sql loop kullanımı
,
pl sql while kullanımı
.
1
Hiç yorum yok
Merhaba,
Bu yazıda PL/SQL'de koşul kontrollerinin nasıl yapıldığını anlatmaya çalışacağım.
IF THEN ELSE KULLANIMI
Bu kullanımda sadece tek bir koşula girebilir. Sıra ile koşulları kontrol eder.
SET SERVEROUTPUT ON
DECLARE
l_gun VARCHAR2(10);
BEGIN
l_gun := TRIM(TO_CHAR(SYSDATE,'DAY'));
IF l_gun IN ('SATURDAY', 'SUNDAY') THEN
DBMS_OUTPUT.PUT_LINE('Haftasonu');
ELSIF l_gun = 'MONDAY' THEN
DBMS_OUTPUT.PUT_LINE('Haftabaşı');
ELSE
DBMS_OUTPUT.PUT_LINE('Haftaiçi');
END IF;
END;
/
CASE KULLANIMI
SET SERVEROUTPUT ON
DECLARE
l_gun VARCHAR2(10);
BEGIN
l_gun := TRIM(TO_CHAR(SYSDATE,'DAY'));
CASE l_gun
WHEN 'SATURDAY' THEN
DBMS_OUTPUT.PUT_LINE('Haftasonu');
WHEN 'SUNDAY' THEN
DBMS_OUTPUT.PUT_LINE('Haftasonu');
WHEN 'MONDAY' THEN
DBMS_OUTPUT.PUT_LINE('Haftabaşı');
ELSE
DBMS_OUTPUT.PUT_LINE('Haftaiçi');
END CASE;
END;
/
LOOP KULLANIMI
LOOP kullanılırken EXIT yazılmazda sonsuz döngüye girecektir.
SET SERVEROUTPUT ON
DECLARE
i NUMBER := 1;
BEGIN
LOOP
EXIT WHEN i>5;
DBMS_OUTPUT.PUT_LINE('i:'||i);
i := i+1;
END LOOP;
END;
/
WHILE LOOP KULLANIMI
SET SERVEROUTPUT ON
DECLARE
i NUMBER := 1;
BEGIN
WHILE i<=5 LOOP
DBMS_OUTPUT.PUT_LINE('i:'||i);
i := i+1;
END LOOP;
END;
/
GOTO KULLANIMI
SET SERVEROUTPUT ON
DECLARE
i NUMBER := 1;
BEGIN
LOOP
IF i>5 THEN
GOTO looptan_cik;
END IF;
DBMS_OUTPUT.PUT_LINE('i:'||i);
i := i+1;
END LOOP;
<<looptan_cik>>
NULL;
END;
/
Faydalı olması dileğiyle,
Alıntıdır
Bu yazıda PL/SQL'de koşul kontrollerinin nasıl yapıldığını anlatmaya çalışacağım.
IF THEN ELSE KULLANIMI
Bu kullanımda sadece tek bir koşula girebilir. Sıra ile koşulları kontrol eder.
SET SERVEROUTPUT ON
DECLARE
l_gun VARCHAR2(10);
BEGIN
l_gun := TRIM(TO_CHAR(SYSDATE,'DAY'));
IF l_gun IN ('SATURDAY', 'SUNDAY') THEN
DBMS_OUTPUT.PUT_LINE('Haftasonu');
ELSIF l_gun = 'MONDAY' THEN
DBMS_OUTPUT.PUT_LINE('Haftabaşı');
ELSE
DBMS_OUTPUT.PUT_LINE('Haftaiçi');
END IF;
END;
/
CASE KULLANIMI
SET SERVEROUTPUT ON
DECLARE
l_gun VARCHAR2(10);
BEGIN
l_gun := TRIM(TO_CHAR(SYSDATE,'DAY'));
CASE l_gun
WHEN 'SATURDAY' THEN
DBMS_OUTPUT.PUT_LINE('Haftasonu');
WHEN 'SUNDAY' THEN
DBMS_OUTPUT.PUT_LINE('Haftasonu');
WHEN 'MONDAY' THEN
DBMS_OUTPUT.PUT_LINE('Haftabaşı');
ELSE
DBMS_OUTPUT.PUT_LINE('Haftaiçi');
END CASE;
END;
/
LOOP KULLANIMI
LOOP kullanılırken EXIT yazılmazda sonsuz döngüye girecektir.
SET SERVEROUTPUT ON
DECLARE
i NUMBER := 1;
BEGIN
LOOP
EXIT WHEN i>5;
DBMS_OUTPUT.PUT_LINE('i:'||i);
i := i+1;
END LOOP;
END;
/
WHILE LOOP KULLANIMI
SET SERVEROUTPUT ON
DECLARE
i NUMBER := 1;
BEGIN
WHILE i<=5 LOOP
DBMS_OUTPUT.PUT_LINE('i:'||i);
i := i+1;
END LOOP;
END;
/
GOTO KULLANIMI
SET SERVEROUTPUT ON
DECLARE
i NUMBER := 1;
BEGIN
LOOP
IF i>5 THEN
GOTO looptan_cik;
END IF;
DBMS_OUTPUT.PUT_LINE('i:'||i);
i := i+1;
END LOOP;
<<looptan_cik>>
NULL;
END;
/
Faydalı olması dileğiyle,
Alıntıdır
Kaydol:
Kayıt Yorumları
(
Atom
)
Hiç yorum yok :
Yorum Gönder