我的编程空间,编程开发者的网络收藏夹
学习永远不晚

如何在SQL Server中生成和使用CRUD存储过程

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

如何在SQL Server中生成和使用CRUD存储过程

大多数数据库系统基于4个最简单的数据操作操作,这些操作称为CRUD。该首字母缩写词代表创建、读取、更新和删除。

在开发和管理数据库时,可以使用CRUD存储过程来执行所有与数据有关的任务。这种存储过程的好处是,一旦编写了一次,便可以根据需要重复使用多次,而无需每次都编写新代码。这是对临时SQL语句的重大改进,临时SQL语句应在每次使用它们时重新编写。

让我们详细了解每个CRUD存储过程。

仔细研究CRUD存储过程

在继续之前,我们要说一下CRUD存储过程的命名。将它们命名为每个过程都包含它们所应用的表的名称,并且以它们所执行的操作的名称结束,这通常是一种很好的做法。这样,为同一表编写的所有过程将被分组在一起,并且更容易搜索。

但是,它不是强制性的,您可以坚持自己喜欢的任何命名模式。

现在,让我们看一下第一种过程类型。

创建程序

这些将执行INSERT语句,创建一个新记录。此类过程应为表的每一列接受一个参数。

IF OBJECT_ID('Sales.usp_Currency_Insert') IS NOT NULL BEGIN      DROP PROC Sales.usp_Currency_Insert  END  GO CREATE PROC Sales.usp_Currency_Insert      @CurrencyCode NCHAR(3),     @Name dbo.Name,     @ModifiedDate datetime AS      SET NOCOUNT ON      SET XACT_ABORT ON  
BEGIN TRAN
 
INSERT INTO Sales.Currency (CurrencyCode, Name, ModifiedDate)
SELECT @CurrencyCode, @Name, @ModifiedDate
 

COMMIT
GO

读取程序

READ过程根据输入参数中提供的主键检索表记录。

IF OBJECT_ID('Sales.usp_Currency_Select') IS NOT NULL BEGIN      DROP PROC Sales.usp_Currency_Select  END GO CREATE PROC Sales.usp_Currency_Select     @CurrencyCode NCHAR(3),     @Name dbo.Name AS     SET NOCOUNT ON      SET XACT_ABORT ON  
BEGIN TRAN
 
SELECT CurrencyCode, Name, ModifiedDate 
FROM   Sales.Currency
WHERE  CurrencyCode = @CurrencyCode AND Name = @Name  
 
COMMIT
GO

更新程序

这些过程使用WHERE子句中指定的记录的主键在表上执行UPDATE语句。就像CREATE过程一样,它为每个表列接受一个参数。

<code>IF OBJECT_ID('Sales.usp_Currency_Update') IS NOT NULL BEGIN      DROP PROC Sales.usp_Currency_Update END  GO CREATE PROC Sales.usp_Currency_Update @CurrencyCode NCHAR(3), @Name dbo.Name, @ModifiedDate datetime AS      SET NOCOUNT ON      SET XACT_ABORT ON  
BEGIN TRAN
 
UPDATE Sales.Currency
SET    ModifiedDate = @ModifiedDate
WHERE  CurrencyCode = @CurrencyCode AND Name = @Name
 

COMMIT
GO</code>

删除程序

此过程将删除该语句的WHERE子句中提供的行。

<code>IF OBJECT_ID('Sales.usp_Currency_Delete') IS NOT NULL BEGIN      DROP PROC Sales.usp_Currency_Delete END  GO CREATE PROC Sales.usp_Currency_Delete  @CurrencyCode NCHAR(3), @Name dbo.Name AS      SET NOCOUNT ON      SET XACT_ABORT ON  
BEGIN TRAN
 
DELETE
FROM   Sales.Currency
WHERE  CurrencyCode = @CurrencyCode AND Name = @Name
 
COMMIT
GO</code>

使用dbForge SQL Complete生成CRUD过程

在SSMS和Visual Studio中均可使用的dbForge SQL Complete插件,我们只需单击几下便可以生成CRUD过程,并具有多种选项,这些选项允许配置这些过程的生成方式。在本文中,我们将使用SSMS展示SQL Complete的功能。

要为一个表生成CRUD过程,右键单击该表,转到SQL Complete菜单,然后单击Script Table as CRUD:

如何在SQL Server中生成和使用CRUD存储过程

完成此操作后,将打开一个新的SQL文件。在这里,您可以看到该表的所有CRUD操作。

如何在SQL Server中生成和使用CRUD存储过程

更改CRUD生成设置

要配置dbForge SQL Complete如何生成CRUD,您首先需要转到窗口顶部的SQL Complete菜单,然后单击“选项”:

如何在SQL Server中生成和使用CRUD存储过程

结果将在“选项”窗口中打开,转到“CRUD”菜单,然后单击“常规”:

如何在SQL Server中生成和使用CRUD存储过程

在此选项卡中,您可以指定CRUD生成过程中包括哪些过程,并指定要使用的哪个列的顺序——按字母顺序还是按序号顺序。

您也可以通过在CRUD菜单中选择相应的选项来分别配置每个过程。首先,您可以手动更改生成的过程的名称:

如何在SQL Server中生成和使用CRUD存储过程

接下来,每个过程都有唯一的选项。

对于SELECT,如果输入参数为null,则有一个Return all data复选框。

对于INSERT,可以指定是否在完成后返回插入的行。

类似的选项可用于UPDATE –它使您可以选择是否要返回更新的行。

没有其他用于DELETE的唯一选项。

最后,对于每个过程,都有“代码模板”部分。在本节中,您可以更改指定过程的代码的生成方式。在代码模板中,以$ name $格式提供了参数(例如$ schema $或$ columns $)。通过更改这些参数,可以修改所生成过程的代码。

结论

如您所见,使用CRUD命令实现和管理数据操作过程比使用临时SQL语句更为可取,并且可以借助dbForge SQL Complete插件轻松完成此操作。


免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

如何在SQL Server中生成和使用CRUD存储过程

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

如何在SQL Server中创建和使用CLR存储过程

在SQL Server中创建和使用CLR存储过程需要以下步骤:创建CLR程序集:首先需要创建一个包含CLR存储过程的程序集。可以使用Visual Studio或者其他CLR开发工具来创建这个程序集。将程序集部署到SQL Server:完成程
如何在SQL Server中创建和使用CLR存储过程
2024-06-03

在SQL Server中如何优化存储过程

要优化存储过程的性能,可以考虑以下几个方面:使用正确的索引:确保存储过程中涉及的表有合适的索引,以提高查询效率。可以使用SQL Server Management Studio的查询执行计划工具来分析查询执行计划,查看是否有适当的索引。避免
在SQL Server中如何优化存储过程
2024-06-03

在 SQL Server 中编写函数和存储过程

SQL 语句的集合包含在存储过程和函数、用于执行某些任务的数据库对象中(或者也可以在数据科学中使用)。两者在很多方面都有所不同。在本文中,我们将详细讨论函数和过程以及它们的差异。 让我们从存储过程开始 -SQL 中的存储过程简单编写
2023-10-22

如何在MySQL中使用存储过程和函数?

如何在MySQL中使用存储过程和函数?在MySQL中,存储过程和函数是被封装的一组SQL语句,可以被重复调用。存储过程是一组可以在服务器上执行的SQL语句集合,而函数则是一个独立的且可重用的代码块。两者的不同之处在于,存储过程可以返回多个结
2023-10-22

在MySQL中如何使用存储过程和触发器

在MySQL中,可以使用存储过程和触发器来实现一些特定的功能。下面分别介绍如何创建和使用存储过程和触发器:存储过程:存储过程是一组为了完成特定任务的SQL语句集合,可以被存储在数据库中并在需要时调用执行。使用存储过程可以简化复杂的操作和提高
在MySQL中如何使用存储过程和触发器
2024-04-09

如何在 PHP 中使用 MySQL 存储过程?

要在 php 中使用 mysql 存储过程:使用 pdo 或 mysqli 扩展连接到 mysql 数据库。准备调用存储过程的语句。执行存储过程。处理结果集(如果存储过程返回结果)。关闭数据库连接。如何在 PHP 中使用 MySQL 存储过
如何在 PHP 中使用 MySQL 存储过程?
2024-05-11

Navicat在存储过程中如何使用变量和参数

在Navicat中,存储过程可以使用变量和参数来增强灵活性和可重用性。以下是在Navicat中如何使用变量和参数的步骤:定义变量:在存储过程中,可以使用DECLARE语句来定义变量。变量可以用来存储查询结果、临时值或其他数据。DECLARE
Navicat在存储过程中如何使用变量和参数
2024-05-10

MariaDB中如何使用存储过程和函数

在MariaDB中,您可以使用存储过程和函数来将一系列SQL语句封装在一个单元内,然后可以通过调用该存储过程或函数来执行这些SQL语句。以下是如何在MariaDB中创建和使用存储过程和函数的基本步骤:创建存储过程:DELIMITER //C
MariaDB中如何使用存储过程和函数
2024-03-15

编程热搜

目录