Tárolt eljárások SQL-ben | Áttekintés

Ebben a blogban azokról az SQL-ben tárolt eljárásokról fogunk beszélni, amelyek segítségével elmenthet egy kódkészletet, és ismételten használhatja, amikor csak szüksége van rá. A tárolt eljárások hasonlóak a nézetekhez. A tárolt eljárásokkal azonban végrehajthat például DROP, TRUNCATE, DELETE stb., amelyeket nem tud végrehajtani nézetekkel.

A tárolt eljárások szintén előre le vannak fordítva, így gyorsabban futnak, mint a nézetek. Ezenkívül minimalizálja az adatbázis-kiszolgálónak küldött adatok mennyiségét.

Tartalomjegyzék

Tárolt eljárások szintaxisa SQL-ben: Paraméterek nélkül

Paraméterek nélküli tárolt eljárás létrehozásához a CREATE funkcióval kell kezdenie . Ezután adja hozzá a PROC függvényt, közvetlenül utána írja be az eljárás nevét, és adja hozzá az AS függvényt.

Tárolt eljárások SQL-ben |  Áttekintés

A tárolt eljárás létrehozása hasonló a táblák és nézetek létrehozásához. A különbség azonban az adatgyűjtés folyamatában van.

Például, ha adatokat szeretnénk lekérni egy nézetből, akkor a „ SELECT * FROM view_name ” paramétert használjuk. Másrészt a tárolt eljárásokhoz az EXEC-et használjuk, ami „végrehajtást” jelent, majd utána írjuk be a tárolt eljárás nevét .

Tárolt eljárások SQL-ben |  Áttekintés

Miután végrehajtottunk egy tárolt eljárást , az az Ön által hozzáadott utasítások vagy parancsok alapján is megjeleníti az információkat.

Tárolt eljárások szintaxisa SQL-ben: Paraméterekkel

Térjünk át ide. A folyamat hasonló az előző példámhoz, amelyet bemutattam. Az egyetlen különbség az, hogy az AS függvény előtt meg kell adni a paramétereket, és közvetlenül utána az adattípust is.

Tárolt eljárások SQL-ben |  Áttekintés

A parancsokban a tárolt eljárás létrehozása során deklarált paramétert is használhatja. Ezzel időt takaríthat meg több érték megadásával. Például a customerID1 , customerID2 stb. manuális beírása helyett a @custid vagy a paramétert használtuk, hogy elkerüljük a hosszú kódkészletet.

Tárolt eljárások SQL-ben |  Áttekintés

Kérjük, vegye figyelembe, hogy paraméter használatakor vagy belefoglalásakor fontos a @ szimbólum használata. Tetszőleges számú paramétert is megadhat, nem csak egyet. Így hajtjuk végre a tárolt eljárásokat paraméterekkel.

Tárolt eljárások SQL-ben |  Áttekintés

Mint látható, az 1 -es értékű paramétert is használtuk a tárolt eljárás végrehajtása során. Ez csak a custid1 információit jeleníti meg .

Az SSMS-ben tárolt eljárások mintaforgatókönyve

Nézzünk még példákat az SQL-ben tárolt eljárásokra. Először egy minta tárolt eljárást fogok létrehozni az alább kiemelt paranccsal.

Tárolt eljárások SQL-ben |  Áttekintés

A tárolt eljárás létrehozásának elnevezési konvenciójához általában az „usp” vagy az „sp” kifejezést használjuk annak jelzésére, hogy ez egy tárolt eljárás. Ha kíváncsi, mit jelent az „usp”, egyszerűen a felhasználó által meghatározott tárolt eljárást jelenti. 

Ezután lekérdezéseket fogunk írni a tárolt eljáráshoz, amelyet a végrehajtáskor feldolgozni kell.

Tárolt eljárások SQL-ben |  Áttekintés

Az előző példában szereplő lekérdezések egyszerűen eltávolítják a dbo.stageOrders nevű táblát . Ezután újra létrehozza a dbo.stageOrders fájlt a Sales.SalesOrderHeader tábla adataival . 

Hozzuk létre ezt a tárolt eljárást a következő kód kiemelésével és az Execute gombra kattintva.

Tárolt eljárások SQL-ben |  Áttekintés

Ezt követően egy ehhez hasonló üzenetet kell látnia.

Tárolt eljárások SQL-ben |  Áttekintés

Ezután végrehajtjuk a tárolt eljárást az EXEC usp_TEST futtatásával .

Tárolt eljárások SQL-ben |  Áttekintés

Az usp_TEST tárolt eljárás végrehajtása után a dbo.stageOrdersnek rendelkeznie kell a Sales.SalesOrderHeader adataival . Ellenőrizzük a dbo.stageOrders tartalmát az alábbi parancs futtatásával.

Tárolt eljárások SQL-ben |  Áttekintés

Ennek eredményeként ezek azok az adatok, amelyeket a dbo.stageOrders -ben hoztunk létre a tárolt eljárásunkhoz hozzáadott parancsok alapján.

Tárolt eljárások SQL-ben |  Áttekintés

Második példa forgatókönyv

Térjünk át egy másik példára. Ezúttal nem szeretném eldobni a dbo.stageOrders táblát, és újra létrehozni ugyanazt a táblát a Sales.SalesOrderHeader táblából származó adatokkal .

Ehelyett csak azt szeretném, hogy a Sales.SalesOrderHeader tábla adatai megjelenjenek, amikor végrehajtom az „ usp_TESTtárolt eljárást .

Ennek végrehajtásához módosítanom kell a nemrégiben létrehozott tárolt eljárást az ALTER utasítás használatával.

Tárolt eljárások SQL-ben |  Áttekintés

Ebben a példában az ALTER utasítást használtuk, amely a tárolt eljárásunk módosítására szolgál. Ezt nézetekre és táblázatokra is alkalmazhatja. Miután futtattuk a fenti képernyőképen látható kódot, módosítania kell a tárolt eljárásunk által feldolgozandó lekérdezéseket.

Ezúttal nem fog újra létrehozni egyetlen táblázatot sem, mint korábban. Ha végrehajtjuk az „ usp_TEST ” parancsot, akkor az csak a Sales.SalesOrderHeader táblából hozza az adatokat .

Tárolt eljárások SQL-ben |  Áttekintés

Tárolt eljárások SQL-ben |  Áttekintés

Harmadik példa forgatókönyv

Vegyünk egy másik példát. Ezúttal újra felhasználjuk a dbo.stageOrders táblát, amely az SSMS- ben tárolt eljárás létrehozásának első példájában volt . Ezzel a példával kezdjük a dbo.stageOrders tábla kiválasztásával. 

Tárolt eljárások SQL-ben |  Áttekintés

A dbo.stageOrders összes adatának kiválasztásakor az eredményeknek ilyeneknek kell lenniük.

Tárolt eljárások SQL-ben |  Áttekintés

Most ürítsük ki a dbo.stageOrders táblát az usp_TEST végrehajtásával . Ezt a következő parancs hozzáadásával tehetjük meg.

Tárolt eljárások SQL-ben |  Áttekintés

A TRUNCATE TABLE parancs hozzáadása után frissítenünk kell az usp_TEST fájlt .

Tárolt eljárások SQL-ben |  Áttekintés

Ezt követően egy üzenetnek kell megjelennie , amely szerint a parancsok sikeresen befejeződtek . Ezután újra végrehajtjuk az usp_TEST parancsot .

Tárolt eljárások SQL-ben |  Áttekintés

Az usp_TEST végrehajtásakor megjelenik a Sales.SalesOrderHeader összes rekordja , és kiüríti a dbo.stageOrders táblát is. 

Tárolt eljárások SQL-ben |  Áttekintés

Annak ellenőrzéséhez, hogy a dbo.stageOrders tábla üres-e, ki kell jelölnünk a következő paranccsal, és végre kell hajtanunk.

Tárolt eljárások SQL-ben |  Áttekintés

A fenti kód futtatásakor azt látjuk, hogy a dbo.stageOrders tábla most üres. Ez a TRUNCATE TABLE parancsnak köszönhető, amelyet az usp_TEST frissítésére használtunk .

Tárolt eljárások SQL-ben |  Áttekintés

A mentett tárolt eljárások helye az SQL-ben

Ha látni szeretné, hogy a tárolt eljárás hova kerül mentésre, lépjen az Object Explorer panelre a bal oldalon, és kattintson a „ + ” ikonra az adatbázis előtt, amelyen dolgozik.

Tárolt eljárások SQL-ben |  Áttekintés

Ezután kattintson a jobb gombbal a Programozhatóság elemre , és válassza a Frissítés lehetőséget .

Tárolt eljárások SQL-ben |  Áttekintés

Tárolt eljárások SQL-ben |  Áttekintés

A „ + ” ikonra kattintva bontsa ki a Programozhatóság mappát vagy csoportot . Ezután bontsa ki a Tárolt eljárások csoportot ugyanazzal a lépéssel. A Tárolt eljárások csoportban látnia kell a dbo.usp_TEST fájlt .

Tárolt eljárások SQL-ben |  Áttekintés

Tárolt eljárások SQL-ben |  Áttekintés

Ha szeretné ellenőrizni, hogy az SQL-ben egy adott tárolt eljárás milyen parancsokat vagy lekérdezéseket hajt végre, kattintson a jobb gombbal egy tárolt eljárásra, és kövesse az alábbi képernyőképen látható lépéseket.

Tárolt eljárások SQL-ben |  Áttekintés

Ezt követően megnyitja a tárolt eljárást egy másik lapon, ahol láthatja a benne található parancsokat. Így néz ki a dbo.usp_TEST megnyitásakor.

Tárolt eljárások SQL-ben |  Áttekintés

Amint láthatja, van néhány alapértelmezett parancs a CREATE utasítás előtt. Egyszerűen törölheti, ha akarja. 

Tárolt eljárások SQL-ben |  Áttekintés

Most már tudja, hogyan ellenőrizheti, hogy az SQL-ben tárolt eljárás milyen parancsokat hajt végre.

Tárolt eljárás létrehozása SQL-ben paraméterekkel

Ezután létrehozunk egy tárolt eljárást paraméterekkel. Például a következő kódot fogjuk használni egy új tárolt eljárás létrehozásához.

Tárolt eljárások SQL-ben |  Áttekintés

A példakódban ugyanezt a folyamatot használtam az usp_GetCustomer nevű tárolt eljárás létrehozására . Ezután hozzáadtam egy @CustomerID paramétert INT bemeneti típussal .

Vegye figyelembe, hogy miután hozzáadott egy paramétert egy tárolt eljárás létrehozásához, mindig meg kell adnia egy paramétert, amikor parancsot akar végrehajtani.

Nézzük meg, mi történik, ha az usp_GetCustomer parancsot paraméter megadása nélkül hajtjuk végre.

Tárolt eljárások SQL-ben |  Áttekintés

Az usp_GetCustomer paraméter nélküli futtatásakor hibaüzenet jelent meg. Így nézne ki, ha egy paraméterrel végrehajtjuk az usp_GetCustomer parancsot .

Tárolt eljárások SQL-ben |  Áttekintés

Egy megadott paraméterrel megfelelő eredményt tudunk elérni a tárolt eljárásunk végrehajtása során .

Tárolt eljárás létrehozása alapértelmezett értékkel

Ha el szeretné kerülni, hogy hibaüzenetet kapjon egy tárolt eljárás paraméterrel végrehajtásakor, beállíthat egy alapértelmezett értéket, amely alapértelmezett paraméterként fog szolgálni.

Például létrehozunk egy usp_GetOrdersByYear nevű tárolt eljárást .

Ezután hozzáadok egy @OrderYear paramétert „ INT ” bemeneti típussal és egy alapértelmezett értékkel, amely megegyezik a 2011-gyel .

Tárolt eljárások SQL-ben |  Áttekintés

Ha az usp_GetOrdersByYear parancsot paraméter megadása nélkül hajtjuk végre , akkor a 2011-es évszámú rekordokat jeleníti meg .

Tárolt eljárások SQL-ben |  Áttekintés

Tárolt eljárások SQL-ben |  Áttekintés

Másrészt, ha az usp_GetOrdersByYear parancsot 2014 paraméterrel hajtjuk végre, akkor a 2014-es évszámmal kell rekordokat megjelenítenie .

Tárolt eljárások SQL-ben |  Áttekintés

Tárolt eljárások SQL-ben |  Áttekintés

Így hasznosítja a tárolt eljárásokat a napi adatkezelési feladatai során.



Következtetés

Mindent figyelembe véve megtanulta, mi az SQL-ben tárolt eljárás, és mi a célja. Megbeszéltük az ALTER utasítást is, amelyet a jelenlegi tárolt eljárás módosítására vagy frissítésére használnak.

Ezenkívül megtanulta, hogy különböző módszerek léteznek a tárolt eljárások létrehozására SQL-ben, és megtanulta, hogyan kerülheti el a hibákat a tárolt eljárások végrehajtásakor egy alapértelmezett érték megadásával.

A legfontosabb, hogy megtanulta használni a tárolt eljárásokat a parancskészletek tárolására, hogy elkerülje a hosszú kódkészletek ismételt futtatását. Utolsó emlékeztetőként ne felejtse el használni a " @ " szimbólumot a paraméter megadásakor.

Minden jót,

Hafiz


Dátumtáblázat létrehozása a LuckyTemplates alkalmazásban

Dátumtáblázat létrehozása a LuckyTemplates alkalmazásban

Tudja meg, miért fontos egy dedikált dátumtáblázat a LuckyTemplatesben, és ismerje meg ennek leggyorsabb és leghatékonyabb módját.

LuckyTemplates mobil jelentéskészítési tippek és technikák

LuckyTemplates mobil jelentéskészítési tippek és technikák

Ez a rövid oktatóanyag kiemeli a LuckyTemplates mobil jelentési funkcióját. Megmutatom, hogyan készíthet hatékony jelentéseket mobileszközökön.

Professzionális szolgáltatáselemzési jelentések LuckyTemplatesben

Professzionális szolgáltatáselemzési jelentések LuckyTemplatesben

Ebben a LuckyTemplates bemutatóban olyan jelentéseket tekintünk át, amelyek professzionális szolgáltatáselemzést mutatnak be egy olyan cégtől, amely több szerződéssel és ügyfél-elkötelezettséggel rendelkezik.

Microsoft Power Platform frissítések | Microsoft Ignite 2021

Microsoft Power Platform frissítések | Microsoft Ignite 2021

Tekintse át a Power Apps és a Power Automate legfontosabb frissítéseit, valamint azok előnyeit és következményeit a Microsoft Power Platform számára.

Gyakori SQL-függvények: Áttekintés

Gyakori SQL-függvények: Áttekintés

Fedezzen fel néhány gyakori SQL-függvényt, amelyeket használhatunk, például a karakterláncot, a dátumot és néhány speciális függvényt az adatok feldolgozásához vagy manipulálásához.

LuckyTemplates sablonok létrehozása: útmutató és tippek

LuckyTemplates sablonok létrehozása: útmutató és tippek

Ebből az oktatóanyagból megtudhatja, hogyan hozhatja létre a tökéletes LuckyTemplates sablont, amely az Ön igényeinek és preferenciáinak megfelelően van konfigurálva.

Mezőparaméterek és kis többszörösek a LuckyTemplatesben

Mezőparaméterek és kis többszörösek a LuckyTemplatesben

Ebben a blogban bemutatjuk, hogyan lehet a mezőparamétereket kis többszörösekkel rétegezni, hogy hihetetlenül hasznos betekintést és látványelemeket hozzon létre.

LuckyTemplates rangsor és egyéni csoportosítás

LuckyTemplates rangsor és egyéni csoportosítás

Ebből a blogból megtudhatja, hogyan használhatja a LuckyTemplates rangsorolási és egyéni csoportosítási funkcióit a mintaadatok szegmentálására és kritériumok szerinti rangsorolására.

A LuckyTemplatesben csak egy meghatározott dátumig összesített összeg látható

A LuckyTemplatesben csak egy meghatározott dátumig összesített összeg látható

Ebben az oktatóanyagban egy konkrét technikát fogok bemutatni, hogyan jelenítheti meg a kumulatív összeget csak egy adott dátumig a LuckyTemplates vizualizációjában.

Bullet Charts: speciális egyéni látványelemek a LuckyTemplates számára

Bullet Charts: speciális egyéni látványelemek a LuckyTemplates számára

Ismerje meg, hogyan hozhat létre és testreszabhat Bullet diagramokat a LuckyTemplates alkalmazásban, amelyeket főként a teljesítmény mérésére használnak a célhoz vagy az előző évekhez képest.