<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="hu">
	<id>https://vik.wiki/index.php?action=history&amp;feed=atom&amp;title=Adatb%C3%A1zisok_szerver_oldali_programoz%C3%A1sa_Labor%2C_2006.04.18.</id>
	<title>Adatbázisok szerver oldali programozása Labor, 2006.04.18. - Laptörténet</title>
	<link rel="self" type="application/atom+xml" href="https://vik.wiki/index.php?action=history&amp;feed=atom&amp;title=Adatb%C3%A1zisok_szerver_oldali_programoz%C3%A1sa_Labor%2C_2006.04.18."/>
	<link rel="alternate" type="text/html" href="https://vik.wiki/index.php?title=Adatb%C3%A1zisok_szerver_oldali_programoz%C3%A1sa_Labor,_2006.04.18.&amp;action=history"/>
	<updated>2026-05-16T19:22:02Z</updated>
	<subtitle>Az oldal laptörténete a wikiben</subtitle>
	<generator>MediaWiki 1.43.8</generator>
	<entry>
		<id>https://vik.wiki/index.php?title=Adatb%C3%A1zisok_szerver_oldali_programoz%C3%A1sa_Labor,_2006.04.18.&amp;diff=163844&amp;oldid=prev</id>
		<title>2001:738:2001:2078:0:208:37:0: Új oldal, tartalma: „{{GlobalTemplate|Valaszthato|AdatbServerProgJegyzet20060418}}  &lt;!--  * Set DENYTOPICVIEW = TWikiGuest --&gt;   &lt;style&gt;  	code.pre { white-space: pre; display: block; m…”</title>
		<link rel="alternate" type="text/html" href="https://vik.wiki/index.php?title=Adatb%C3%A1zisok_szerver_oldali_programoz%C3%A1sa_Labor,_2006.04.18.&amp;diff=163844&amp;oldid=prev"/>
		<updated>2013-03-31T19:03:41Z</updated>

		<summary type="html">&lt;p&gt;Új oldal, tartalma: „{{GlobalTemplate|Valaszthato|AdatbServerProgJegyzet20060418}}  &amp;lt;!--  * Set DENYTOPICVIEW = &lt;a href=&quot;/index.php?title=TWikiGuest&amp;amp;action=edit&amp;amp;redlink=1&quot; class=&quot;new&quot; title=&quot;TWikiGuest (a lap nem létezik)&quot;&gt;TWikiGuest&lt;/a&gt; --&amp;gt;   &amp;lt;style&amp;gt;  	code.pre { white-space: pre; display: block; m…”&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Új lap&lt;/b&gt;&lt;/p&gt;&lt;div&gt;{{GlobalTemplate|Valaszthato|AdatbServerProgJegyzet20060418}}&lt;br /&gt;
&lt;br /&gt;
&amp;lt;!-- &lt;br /&gt;
* Set DENYTOPICVIEW = [[TWikiGuest]]&lt;br /&gt;
--&amp;gt; &lt;br /&gt;
&lt;br /&gt;
&amp;lt;style&amp;gt; &lt;br /&gt;
	code.pre { white-space: pre; display: block; margin-top: 2px; margin-bottom: 2px; }&lt;br /&gt;
	li { line-height: 18px; }&lt;br /&gt;
&amp;lt;/style&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;br/&amp;gt; [[AdatbServerProgJegyzet20060414|&amp;amp;lt;&amp;amp;lt;]] Labor, 2006.04.18. [[AdatbServerProgJegyzet20060421|&amp;amp;gt;&amp;amp;gt;]]&lt;br /&gt;
&lt;br /&gt;
==Dinamikus SQL==&lt;br /&gt;
&lt;br /&gt;
&amp;lt;ol&amp;gt;&lt;br /&gt;
&amp;lt;li&amp;gt; Hozz létre egy csomagot, amiben a gyakorlat során elkészítendő feladatokat fogod&lt;br /&gt;
megvalósítani!&lt;br /&gt;
&amp;lt;li&amp;gt; Írj egy tárolt eljárást, ami egy tábla sorait törli ki. Az eljárás bemenete a tábla neve és&lt;br /&gt;
a törlend( sorokat definiáló feltétel legyen. Amennyiben nincs megadva feltétel, az&lt;br /&gt;
eljárás a bemenetként kapott tábla összes sorát törölje. Az eljárást próbáld is ki!&lt;br /&gt;
&lt;br /&gt;
&amp;lt;code class=&amp;quot;pre&amp;quot;&amp;gt;CREATE OR REPLACE PACKAGE dynasql IS&lt;br /&gt;
	PROCEDURE deletefrom(tablename VARCHAR2, condition VARCHAR2);&lt;br /&gt;
END dynasql;&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;code class=&amp;quot;pre&amp;quot;&amp;gt;CREATE OR REPLACE PACKAGE BODY dynasql IS&lt;br /&gt;
	PROCEDURE deletefrom(tablename VARCHAR2, condition VARCHAR2) IS&lt;br /&gt;
		query VARCHAR2(500);&lt;br /&gt;
	BEGIN&lt;br /&gt;
		query := &amp;#039;DELETE FROM &amp;#039; ||| tablename |||| &amp;#039; WHERE &amp;#039; || NVL(condition, &amp;#039;0=0&amp;#039;);&lt;br /&gt;
		DBMS_OUTPUT.PUT_LINE(query);&lt;br /&gt;
		EXECUTE IMMEDIATE query;&lt;br /&gt;
	END;&lt;br /&gt;
END dynasql;&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=EXEC dynasql.deletefrom(&amp;#039;exam&amp;#039;, &amp;#039;ex_id=6&amp;#039;);=&lt;br /&gt;
&lt;br /&gt;
&amp;lt;li&amp;gt; Hozz létre egy típust, amiben tetszőleges számú tábla nevét tudod majd tárolni!&lt;br /&gt;
&amp;lt;li&amp;gt; Írj egy tárolt eljárást, aminek bemenő paramétere táblák neveinek tömbje, feladata&lt;br /&gt;
pedig, hogy kitörölje a bemenetként megkapott táblákat. A sikeres vagy sikertelen&lt;br /&gt;
törlésekről a kimenetre írj üzenetet. Dobj hibát, amennyiben nem lehet az összes&lt;br /&gt;
táblát kitörölni, mert esetleg a listából hiányzik egy olyan tábla, ami hivatkozik egy&lt;br /&gt;
listabeli táblára.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;code class=&amp;quot;pre&amp;quot;&amp;gt;CREATE OR REPLACE PACKAGE dynasql IS&lt;br /&gt;
	TYPE tablalista IS TABLE OF VARCHAR2(30);&lt;br /&gt;
	PROCEDURE droptables(tables tablalista);&lt;br /&gt;
END dynasql;&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;code class=&amp;quot;pre&amp;quot;&amp;gt;CREATE OR REPLACE PACKAGE BODY dynasql IS&lt;br /&gt;
	tablanemletezik EXCEPTION;&lt;br /&gt;
	tablanemtorolheto EXCEPTION;&lt;br /&gt;
&amp;amp;nbsp;	&lt;br /&gt;
	PRAGMA EXCEPTION_INIT(tablanemletezik, -00942);&lt;br /&gt;
	PRAGMA EXCEPTION_INIT(tablanemtorolheto, -02449);&lt;br /&gt;
&amp;amp;nbsp;&lt;br /&gt;
	PROCEDURE droptables(tables tablalista) IS&lt;br /&gt;
		query VARCHAR2(500);&lt;br /&gt;
		torolve INT := 0;&lt;br /&gt;
	BEGIN&lt;br /&gt;
		FOR i IN tables.FIRST..tables.LAST LOOP&lt;br /&gt;
			FOR i IN tables.FIRST..tables.LAST LOOP&lt;br /&gt;
				BEGIN&lt;br /&gt;
					query := &amp;#039;DROP TABLE &amp;#039; | tables(i);&lt;br /&gt;
					EXECUTE IMMEDIATE query;&lt;br /&gt;
					torolve := torolve+1;&lt;br /&gt;
					DBMS_OUTPUT.PUT_LINE(&amp;#039;Törölve&amp;amp;#58; &amp;#039; | tables(i));&lt;br /&gt;
				EXCEPTION&lt;br /&gt;
					WHEN tablanemletezik THEN&lt;br /&gt;
						DBMS_OUTPUT.PUT_LINE(&amp;#039;Nem létezik: &amp;#039; | tables(i));&lt;br /&gt;
					WHEN tablanemtorolheto THEN&lt;br /&gt;
						DBMS_OUTPUT.PUT_LINE(&amp;#039;Nem törölhető: &amp;#039; | tables(i));&lt;br /&gt;
				END;&lt;br /&gt;
			END LOOP;&lt;br /&gt;
		END LOOP;&lt;br /&gt;
		IF torolve&amp;lt;tables.COUNT THEN&lt;br /&gt;
			RAISE_APPLICATION_ERROR(-20100, &amp;#039;Nem sikerült minden táblát törölni&amp;#039;);&lt;br /&gt;
		END IF;&lt;br /&gt;
	END;&lt;br /&gt;
END dynasql;&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;code class=&amp;quot;pre&amp;quot;&amp;gt;DECLARE&lt;br /&gt;
	t dynasql.tablalista;&lt;br /&gt;
BEGIN&lt;br /&gt;
	t:=dynasql.tablalista(&amp;#039;felkesz&amp;#039;, &amp;#039;anyag&amp;#039;, &amp;#039;felkesz_anyag&amp;#039;);&lt;br /&gt;
	dynasql.droptables(t);&lt;br /&gt;
END;&amp;lt;/code&amp;gt;&lt;br /&gt;
&amp;lt;/ol&amp;gt;&lt;br /&gt;
-- [[PallosPeter|Peti]] - 2006.04.18.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
[[Category:Valaszthato]]&lt;/div&gt;</summary>
		<author><name>2001:738:2001:2078:0:208:37:0</name></author>
	</entry>
</feed>