選單
×
   ❮     
HTML CSS JAVASCRIPT SQL PYTHON JAVA PHP HOW TO W3.CSS C C++ C# BOOTSTRAP REACT MYSQL JQUERY EXCEL XML DJANGO NUMPY PANDAS NODEJS R TYPESCRIPT ANGULAR GIT POSTGRESQL MONGODB ASP AI GO KOTLIN SASS VUE DSA GEN AI SCIPY AWS CYBERSECURITY DATA SCIENCE
     ❯   

SQL 教程

SQL HOME SQL Intro SQL Syntax SQL Select SQL Select Distinct SQL Where SQL Order By SQL And SQL Or SQL Not SQL Insert Into SQL Null Values SQL Update SQL Delete SQL Select Top SQL Aggregate Functions SQL Min and Max SQL Count SQL Sum SQL Avg SQL Like SQL Wildcards SQL In SQL Between SQL Aliases SQL Joins SQL Inner Join SQL Left Join SQL Right Join SQL Full Join SQL Self Join SQL Union SQL Group By SQL Having SQL Exists SQL Any, All SQL Select Into SQL Insert Into Select SQL Case SQL Null Functions SQL Stored Procedures SQL Comments SQL Operators

SQL 資料庫

SQL Create DB SQL Drop DB SQL Backup DB SQL Create Table SQL Drop Table SQL Alter Table SQL Constraints SQL Not Null SQL Unique SQL Primary Key SQL Foreign Key SQL Check SQL Default SQL Index SQL Auto Increment SQL Dates SQL Views SQL Injection SQL Hosting SQL Data Types

SQL 參考

SQL 關鍵字 MySQL 函式 SQL Server 函式 MS Access 函式 SQL 快速參考

SQL 示例

SQL 示例 SQL 編輯器 SQL 測驗 SQL 練習 SQL Server SQL Bootcamp SQL 證書

SQL SQL Server 儲存過程


什麼是儲存過程?

儲存過程是預先準備好的 SQL 程式碼,您可以儲存它,以便程式碼可以一次又一次地重用。

因此,如果您有一個需要反覆編寫的 SQL 查詢,請將其儲存為儲存過程,然後只需呼叫它來執行。

您還可以向儲存過程傳遞引數,以便儲存過程可以根據傳遞的引數值起作用。

儲存過程語法

CREATE PROCEDURE procedure_name
AS
sql_statement
GO;

執行儲存過程

EXEC procedure_name;

演示資料庫

以下是 Northwind 示例資料庫中“Customers”表的選段

CustomerID CustomerName ContactName Address City PostalCode Country
1

Alfreds Futterkiste Maria Anders Obere Str. 57 Berlin 12209 Germany
2 Ana Trujillo Emparedados y helados Ana Trujillo Avda. de la Constitución 2222 México D.F. 05021 Mexico
3 Antonio Moreno Taquería Antonio Moreno Mataderos 2312 México D.F. 05023 Mexico
4

Around the Horn Thomas Hardy 120 Hanover Sq. London WA1 1DP UK
5 Berglunds snabbköp Christina Berglund Berguvsvägen 8 Luleå S-958 22 Sweden

儲存過程示例

以下 SQL 語句建立一個名為“SelectAllCustomers”的儲存過程,該過程從“Customers”表中選擇所有記錄

示例

CREATE PROCEDURE SelectAllCustomers
AS
SELECT * FROM Customers
GO;

如下執行上面的儲存過程

示例

EXEC SelectAllCustomers;


帶一個引數的儲存過程

以下 SQL 語句建立一個儲存過程,該過程從“Customers”表中選擇特定城市的客戶

示例

CREATE PROCEDURE SelectAllCustomers @City nvarchar(30)
AS
SELECT * FROM Customers WHERE City = @City
GO;

如下執行上面的儲存過程

示例

EXEC SelectAllCustomers @City = 'London';

帶多個引數的儲存過程

設定多個引數非常簡單。只需列出每個引數和資料型別,用逗號分隔,如下所示。

以下 SQL 語句建立一個儲存過程,該過程從“Customers”表中選擇特定城市和特定郵政編碼的客戶

示例

CREATE PROCEDURE SelectAllCustomers @City nvarchar(30), @PostalCode nvarchar(10)
AS
SELECT * FROM Customers WHERE City = @City AND PostalCode = @PostalCode
GO;

如下執行上面的儲存過程

示例

EXEC SelectAllCustomers @City = 'London', @PostalCode = 'WA1 1DP';

×

聯絡銷售

如果您想將 W3Schools 服務用於教育機構、團隊或企業,請傳送電子郵件給我們
sales@w3schools.com

報告錯誤

如果您想報告錯誤,或想提出建議,請傳送電子郵件給我們
help@w3schools.com

W3Schools 經過最佳化,旨在方便學習和培訓。示例可能經過簡化,以提高閱讀和學習體驗。教程、參考資料和示例會不斷審查,以避免錯誤,但我們無法保證所有內容的完全正確性。使用 W3Schools 即表示您已閱讀並接受我們的使用條款Cookie 和隱私政策

版權所有 1999-2024 Refsnes Data。保留所有權利。W3Schools 由 W3.CSS 提供支援