百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

SQLSERVER:存储过程和函数

yuyutoo 2025-01-10 18:16 2 浏览 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 中实现数据操作逻辑的重要工具,它们可以提高代码的可读性和维护性,并有助于实现复杂的业务逻辑。正确地使用这些工具能够提升数据库操作的效率和可靠性。在设计数据库应用时,合理选择使用存储过程或函数对于构建高效、可维护的数据库系统至关重要。

相关推荐

史上最全的浏览器兼容性问题和解决方案

微信ID:WEB_wysj(点击关注)◎◎◎◎◎◎◎◎◎一┳═┻︻▄(页底留言开放,欢迎来吐槽)●●●...

平面设计基础知识_平面设计基础知识实验收获与总结
平面设计基础知识_平面设计基础知识实验收获与总结

CSS构造颜色,背景与图像1.使用span更好的控制文本中局部区域的文本:文本;2.使用display属性提供区块转变:display:inline(是内联的...

2025-02-21 16:01 yuyutoo

写作排版简单三步就行-工具篇_作文排版模板

和我们工作中日常word排版内部交流不同,这篇教程介绍的写作排版主要是用于“微信公众号、头条号”网络展示。写作展现的是我的思考,排版是让写作在网格上更好地展现。在写作上花费时间是有累积复利优势的,在排...

写一个2048的游戏_2048小游戏功能实现

1.创建HTML文件1.打开一个文本编辑器,例如Notepad++、SublimeText、VisualStudioCode等。2.将以下HTML代码复制并粘贴到文本编辑器中:html...

今天你穿“短袖”了吗?青岛最高23℃!接下来几天气温更刺激……

  最近的天气暖和得让很多小伙伴们喊“热”!!!  昨天的气温到底升得有多高呢?你家有没有榜上有名?...

CSS不规则卡片,纯CSS制作优惠券样式,CSS实现锯齿样式

之前也有写过CSS优惠券样式《CSS3径向渐变实现优惠券波浪造型》,这次再来温习一遍,并且将更为详细的讲解,从布局到具体样式说明,最后定义CSS变量,自定义主题颜色。布局...

柠檬科技肖勃飞:大数据风控助力信用社会建设

...

你的自我界限够强大吗?_你的自我界限够强大吗英文

我的结果:A、该设立新的界限...

行内元素与块级元素,以及区别_行内元素和块级元素有什么区别?

行内元素与块级元素首先,CSS规范规定,每个元素都有display属性,确定该元素的类型,每个元素都有默认的display值,分别为块级(block)、行内(inline)。块级元素:(以下列举比较常...

让“成都速度”跑得潇潇洒洒,地上地下共享轨交繁华
让“成都速度”跑得潇潇洒洒,地上地下共享轨交繁华

去年的两会期间,习近平总书记在参加人大会议四川代表团审议时,对治蜀兴川提出了明确要求,指明了前行方向,并带来了“祝四川人民的生活越来越安逸”的美好祝福。又是一年...

2025-02-21 16:00 yuyutoo

今年国家综合性消防救援队伍计划招录消防员15000名

记者24日从应急管理部获悉,国家综合性消防救援队伍2023年消防员招录工作已正式启动。今年共计划招录消防员15000名,其中高校应届毕业生5000名、退役士兵5000名、社会青年5000名。本次招录的...

一起盘点最新 Chrome v133 的5大主流特性 ?

1.CSS的高级attr()方法CSSattr()函数是CSSLevel5中用于检索DOM元素的属性值并将其用于CSS属性值,类似于var()函数替换自定义属性值的方式。...

竞走团体世锦赛5月太仓举行 世界冠军杨家玉担任形象大使

style="text-align:center;"data-mce-style="text-align:...

学物理能做什么?_学物理能做什么 卢昌海

作者:曹则贤中国科学院物理研究所原标题:《物理学:ASourceofPowerforMan》在2006年中央电视台《对话》栏目的某期节目中,主持人问过我一个的问题:“学物理的人,如果日后不...

你不知道的关于这只眯眼兔的6个小秘密
你不知道的关于这只眯眼兔的6个小秘密

在你们忙着给熊本君做表情包的时候,要知道,最先在网络上引起轰动的可是这只脸上只有两条缝的兔子——兔斯基。今年,它更是迎来了自己的10岁生日。①关于德艺双馨“老艺...

2025-02-21 16:00 yuyutoo

取消回复欢迎 发表评论: