SQLSERVER:存储过程和函数
yuyutoo 2025-01-10 18:16 5 浏览 0 评论
在 SQL Server 中,存储过程和函数是数据库编程的基础。它们允许开发者编写 SQL 脚本来执行复杂的操作,同时提供了代码重用和逻辑封装的能力。下面将通过一些实例来详细介绍存储过程和函数的使用。
存储过程(Stored Procedures)
存储过程是一组为了完成特定功能而编写的 SQL 语句,可以接受参数、执行逻辑操作、控制事务等。
实例数据表:Employees
假设我们有以下 Employees 表:
EmployeeID | FirstName | LastName | Position | DepartmentID |
1 | Jane | Doe | Manager | 1 |
2 | John | Smith | Developer | 2 |
3 | Alice | Johnson | Developer | 2 |
表结构与数据
-- 创建Employees表
CREATE TABLE Employees (
EmployeeID INT PRIMARY KEY IDENTITY(1,1) NOT NULL,
FirstName VARCHAR(100),
LastName VARCHAR(100),
Position VARCHAR(100),
DepartmentID INT
);
-- 插入Employees表数据
INSERT INTO Employees (FirstName, LastName, Position, DepartmentID)
VALUES ('Jane', 'Doe', 'Manager', 1),
('John', 'Smith', 'Developer', 2),
('Alice', 'Johnson', 'Developer', 2);
示例脚本 1:创建存储过程
创建一个存储过程来添加新员工。
CREATE PROCEDURE spAddEmployee
@FirstName NVARCHAR(50),
@LastName NVARCHAR(50),
@Position NVARCHAR(50),
@DepartmentID INT
AS
BEGIN
INSERT INTO Employees (FirstName, LastName, Position, DepartmentID)
VALUES (@FirstName, @LastName, @Position, @DepartmentID)
END
GO
示例脚本 2:执行存储过程
EXEC spAddEmployee
@FirstName = N'Emily',
@LastName = N'Clark',
@Position = N'HR',
@DepartmentID = 3;
GO
函数(Functions)
函数是可以返回一个值(标量函数)或一系列值(表值函数)的 SQL 语句块。
示例脚本 3:创建标量函数
创建一个函数来计算特定部门的员工数量。
CREATE FUNCTION fnCountEmployeesByDepartment (@DepartmentID INT)
RETURNS INT
AS
BEGIN
DECLARE @Count INT;
SELECT @Count = COUNT(*) FROM Employees WHERE DepartmentID = @DepartmentID;
RETURN @Count;
END
GO
示例脚本 4:使用标量函数
SELECT dbo.fnCountEmployeesByDepartment(2) AS DevTeamCount;
GO
示例脚本 5:创建表值函数
创建一个函数来获取特定部门的所有员工信息。
CREATE FUNCTION fnEmployeesByDepartment (@DepartmentID INT)
RETURNS TABLE
AS
RETURN (
SELECT * FROM Employees WHERE DepartmentID = @DepartmentID
)
GO
示例脚本 6:使用表值函数
SELECT * FROM dbo.fnEmployeesByDepartment(2);
GO
存储过程和函数的区别
- 存储过程可以执行修改操作,如 INSERT、UPDATE 和 DELETE,而函数通常不用于这些操作,因为它们应该是无副作用的。
- 函数可以嵌入在 SQL 语句中,例如 SELECT 语句,而存储过程需要单独调用。
- 存储过程可以返回多个结果集,函数只能返回一个单一值或表。
总结
存储过程和函数是 SQL Server 中实现数据操作逻辑的重要工具,它们可以提高代码的可读性和维护性,并有助于实现复杂的业务逻辑。正确地使用这些工具能够提升数据库操作的效率和可靠性。在设计数据库应用时,合理选择使用存储过程或函数对于构建高效、可维护的数据库系统至关重要。
相关推荐
- 网络规划建设原来也可以这么简单!
-
废话少说,直接上干货。天气炎热,请各位看官老爷静心阅读。整体思路下图是关于网络建设的所有相关领域,接下来我为大家逐一讲解。网络分层...
- 网络规划设计师笔记-第 1 章 计算机网络原理
-
计算机网络原理1.1计算机网络概论(P1-10)...
- 别输在远见上,网工这样做职业规划,比啥都强
-
01职业中的规划,人生中的buff“职业规划“这个词,其实对很多年轻人,包括曾经年轻的我来说,都不屑一提。...
- 网络规划设计师学习中(个人自学笔记分享1),有一起学习的吗?
-
网络规划设计师,上午考试内容学习:第一章:计算机网络概述(上部分):如果你也在一起学习,那么我们来一起学习吧!坚持1年,争取明年一次性通过!...
- 在微服务中使用 ASP.NET Core 实现事件溯源和 CQRS
-
概述:事件溯源和命令查询责任分离(CQRS)已成为解决微服务设计的复杂性的强大架构模式。基本CQRS表示形式在本文中,我们将探讨ASP.NETCore如何使你能够将事件溯源和CQRS...
- 用 Nginx 部署 ASP.NET Core 应用程序
-
用Nginx部署ASP.NETCore应用程序步骤如下:在Linux中安装.NETCore运行时和Nginx:...
- Asp.net Core启动流程讲解(一)(asp.net core 入门)
-
asp.netcore默认项目包括项目根目录级的Startup.cs、Program.cs、appsettings.json(appsettings.Development.json)launch...
- 十天学会ASP之第五天(十天学会asp教程)
-
学习目的:学会数据库的基本操作1(写入记录)数据库的基本操作无非是:查询记录,写入记录,删除记录,修改记录。今天我们先学习写入记录。先建立一个表单:<formname="form1"met...
- ASP.NET Core 的 WebApplication 类
-
ASP.NETCore提供了3个主机类(Host)。这些类用于配置应用、管理生命周期和启动Web服务。...
- ASP.NET Core中的键控依赖注入(.net依赖注入原理)
-
大家好,我是深山踏红叶,今天我们来聊一聊ASP.NETCore中的FromKeyedServices,它是在.Net8中引入的。这一特性允许通过键(如字符串或枚举)来注册和检索依赖注入(D...
- Asp.net常用方法及request和response-a
-
asp.net教程asp.net常用方法:1、Request.UrlReferrer请求的来源,可以根据这个判断从百度搜的哪个关键词、防下载盗链、防图片盗链,可以伪造(比如迅雷)。(使用全局一般处理...
- asp.net常考面试题(aspnet题库)
-
asp.net常考面试题一,列举ASP.Net页面之间传递值的几种方式?1,使用QueryString,如:......?id=1;response.Redirect()......2,使用Sessi...
- 在Windows系统搭建.NET Core环境并创建运行ASP.NET网站
-
微软于6月27日在红帽DevNation峰会上正式发布了.NETCore1.0、ASP.NET1.0和EntityFrameworkCore1.0,其将全部支持Windows、OSX和...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- mybatis plus (70)
- scheduledtask (71)
- css滚动条 (60)
- java学生成绩管理系统 (59)
- 结构体数组 (69)
- databasemetadata (64)
- javastatic (68)
- jsp实用教程 (53)
- fontawesome (57)
- widget开发 (57)
- vb net教程 (62)
- hibernate 教程 (63)
- case语句 (57)
- svn连接 (74)
- directoryindex (69)
- session timeout (58)
- textbox换行 (67)
- extension_dir (64)
- linearlayout (58)
- vba高级教程 (75)
- iframe用法 (58)
- sqlparameter (59)
- trim函数 (59)
- flex布局 (63)
- contextloaderlistener (56)