一条SQL语句有必要单独做一个存储过程吗?

比如select [A],[B],[C] from [dbo].[D]只有一条,但要调用很多次
2024-12-05 04:50:41
推荐回答(3个)
回答1:

没有必要,做成存储过程得到的那点性能提升几乎可以忽略不计。

事实上,数据库对一些常执行的语句也会做一些存储或优化。

我认为存储过程对性能的提高,来自于SQL语句预编译得到的提升并不是最重要的,而是那些可能需要来回交互多次的查询,用存储过程就节约了数据库与客户端之间交互的时间。比如说,某个查询,先根据参数出某一个条记录,然后根据这条记录的查询结果再查询出若干记录,这时候用存储过程就很有必要了。否则,你要先查处一条,在程序里取出值,然后根据取出的值执行下一条SQL,这个过程是相对耗时的,不如你在存储过程里执行的速度快。

回答2:

其实也不是很必要,你这个是求出了A,B,C这三列嘛,从用户表D里面调出来显示而已

回答3:

存储过程(Stored Procedure)是一组为了完成特定功能的SQL 语句集,经编译后存储在数据库。中用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它。

在SQL Server 的系列版本中存储过程分为两类:系统提供的存储过程和用户自定义存储过程。系统过程主要存储在master 数据库中并以sp_为前缀,并且系统存储过程主要是从系统表中获取信息,从而为系统管理员管理SQL Server 提供支持。通过系统存储过程,MS SQL Server 中的许多管理性或信息性的活动(如了解数据库对象、数据库信息)都可以被顺利有效地完成。尽管这些系统存储过程被放在master 数据库中,但是仍可以在其它数据库中对其进行调用,在调用时不必在存储过程名前加上数据库名。而且当创建一个新数据库时,一些系统存储过程会在新数据库中被自动创建。用户自定义存储过程是由用户创建并能完成某一特定功能(如查询用户所需数据信息)的存储过程。在本章中所涉及到的存储过程主要是指用户自定义存储过程。

存储过程的优点

当利用MS SQL Server 创建一个应用程序时,Transaction-SQL 是一种主要的编程语言。若运用Transaction-SQL 来进行编程,有两种方法。其一是,在本地存储Transaction- SQL 程序,并创建应用程序向SQL Server 发送命令来对结果进行处理。其二是,可以把部分用Transaction-SQL 编写的程序作为存储过程存储在SQL Server 中,并创建应用程序来调用存储过程,对数据结果进行处理存储过程能够通过接收参数向调用者返回结果集,结果集的格式由调用者确定;返回状态值给调用者,指明调用是成功或是失败;包括针对数据库的操作语句,并且可以在一个存储过程中调用另一存储过程。

我们通常更偏爱于使用第二种方法,即在SQL Server 中使用存储过程而不是在客户计算机上调用Transaction-SQL 编写的一段程序,原因在于存储过程具有以下优点:

存储过程允许标准组件式编程

存储过程在被创建以后可以在程序中被多次调用,而不必重新编写该存储过程的SQL 语句。而且数据库专业人员可随时对存储过程进行修改,但对应用程序源代码毫无影响(因为应用程序源代码只包含存储过程的调用语句),从而极大地提高了程序的可移植性。