`
daohao123
  • 浏览: 56961 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

SQL存储过程

    博客分类:
  • DB
阅读更多
一、SQL存储过程的概念,优点及语法
  整理在学习程序过程之前,先了解下什么是存储过程?为什么要用存储过程,他有那些优点

  定义:将常用的或很复杂的工作,预先用SQL语句写好并用一个指定的名称存储起来, 那么以后要叫数据库提供与已定义好的存储过程的功能相同的服务时,只需调用execute,即可自动完成命令。

  讲到这里,可能有人要问:这么说存储过程就是一堆SQL语句而已啊? Microsoft公司为什么还要添加这个技术呢?

  那么存储过程与一般的SQL语句有什么区别呢?

  存储过程的优点:

  1.存储过程只在创造时进行编译,以后每次执行存储过程都不需再重新编译,而一般SQL语句每执行一次就编译一次,所以使用存储过程可提高数据库执行速度。

  2.当对数据库进行复杂操作时(如对多个表进行Update,Insert,Query,Delete时),可将此复杂操作用存储过程封装起来与数据库提供的事务处理结合一起使用。

  3.存储过程可以重复使用,可减少数据库开发人员的工作量

  4.安全性高,可设定只有某此用户才具有对指定存储过程的使用权

  存储过程的种类:

  1.系统存储过程:以sp_开头,用来进行系统的各项设定.取得信息.相关管理工作,

  如 sp_help就是取得指定对象的相关信息

  2.扩展存储过程 以XP_开头,用来调用操作系统提供的功能

  以下为引用的内容:

  exec master..xp_cmdshell 'ping 10.8.16.1'

  3.用户自定义的存储过程,这是我们所指的存储过程

  常用格式

  以下为引用的内容:

  Create procedure procedue_name

  [@parameter data_type][output]

  [with]{recompile|encryption}

  as

  sql_statement

解释:

  output:表示此参数是可传回的

  with {recompile|encryption}

  recompile:表示每次执行此存储过程时都重新编译一次

  encryption:所创建的存储过程的内容会被加密

  二、SQL存储过程学习:存储过程的创建

  表book的内容如下

  编号     书名      价格

  001    C语言入门     $30

  002  PowerBuilder报表开发  $52

  实例1:查询表Book的内容的存储过程


  create proc query_book
  as
  select * from book
  go
  exec query_book


  实例2:加入一笔记录到表book,并查询此表中所有书籍的总金额


  Create proc insert_book
  @param1 char(10),@param2 varchar(20),@param3 money,@param4 money output
  with encryption ---------加密
  as
  insert book(编号,书名,价格) Values(@param1,@param2,@param3)
  select @param4=sum(价格) from book
  go


执行例子:

  declare @total_price money
  exec insert_book '003','Delphi 控件开发指南',$100,@total_price
  print '总金额为'+convert(varchar,@total_price)
  go


  存储过程的3种传回值:

  1.以Return传回整数

  2.以output格式传回参数

  3.Recordset

  传回值的区别:

  output和return都可在批次程式中用变量接收,而recordset则传回到执行批次的客户端中

  实例3:设有两个表为Product,Order,其表内容如下:
以下为引用的内容:

  Product

  产品编号 产品名称 客户订数

  001    钢笔   30

  002    毛笔    50

  003          铅笔    100

  order

  产品编号 客户名 客户订金

  001   南山区  $30

  002   罗湖区  $50

  003   宝安区  $4

  请实现按编号为连接条件,将两个表连接成一个临时表,该表只含编号.产品名.客户名.订金.总金额,

  总金额=订金*订数,临时表放在存储过程中
  代码如下:

  Create proc temp_sale
  as
  select a.产品编号,a.产品名称,b.客户名,b.客户订金,a.客户订数* b.客户订金 as总金额
  into #temptable from Product a inner join order b on a.产品编号=b.产品编号
  if @@error=0
  print 'Good'
  else
  print 'Fail'
  go


  三、SQL存储过程学习:存储过程的调用

  调用带参数存储过程的几种方式

  1) 这也是最简单的方法,两个输入参数,无返回值,用于Insert,Update,Delete操作较多。

  以下为引用的内容:

  conn.Execute "procname varvalue1,varvalue2"

  2) 如果要返回 Recordset 集:

  以下为引用的内容:

  set rs = server.createobject("adodb.recordset")

  rs.Open "Exec procname varvalue1, varvalue2",conn

  3) 以上两种方法都不能有返回值,(Recordset除外),如果要得到返回值,需要用Command的方法。

  首先说明,返回值有两种。一种是在存储过程中直接return一个值,就象C和VB的函数返回值那样;另一种是可以返回多个值,存储这些值的变量名称需要在调用参数中先行指定。

  四、特殊的存储过程-触发器

  1.触发器的概念及作用

  触发器是一种特殊类型的存储过程,它不同于我们前面介绍过的存储过程。触发器主要是通过事件进行触发而被执行的,而存储过程可以通过存储过程名字而被直接调用。当对某一表进行诸如Update、 Insert、 Delete 这些操作时,SQL Server 就会自动执行触发器所定义的SQL 语句,从而确保对数据的处理必须符合由这些SQL 语句所定义的规则。
  触发器的主要作用就是其能够实现由主键和外键所不能保证的复杂的参照完整性和数据的一致性。除此之外,触发器还有其它许多不同的功能:
  (1) 强化约束(Enforce restriction)

  触发器能够实现比CHECK 语句更为复杂的约束。

  (2) 跟踪变化Auditing changes

  触发器可以侦测数据库内的操作,从而不允许数据库中未经许可的指定更新和变化。

  (3) 级联运行(Cascaded operation)。

  触发器可以侦测数据库内的操作,并自动地级联影响整个数据库的各项内容。例如,某个表上的触发器中包含有对另外一个表的数据操作(如删除,更新,插入)而该操作又导致该表上触发器被触发。

  (4) 存储过程的调用(Stored procedure invocation)。

  为了响应数据库更新触,发器可以调用一个或多个存储过程,甚至可以通过外部过程的调用而在DBMS( 数据库管理系统)本身之外进行操作。

  由此可见,触发器可以解决高级形式的业务规则或复杂行为限制以及实现定制记录等一些方面的问题。例如,触发器能够找出某一表在数据修改前后状态发生的差异,并根据这种差异执行一定的处理。此外一个表的同一类型(Insert、 Update、 Delete)的多个触发器能够对同一种数据操作采取多种不同的处理。

  总体而言,触发器性能通常比较低。当运行触发器时,系统处理的大部分时间花费在参照其它表的这一处理上,因为这些表既不在内存中也不在数据库设备上,而删除表和插入表总是位于内存中。可见触发器所参照的其它表的位置决定了操作要花费的时间长短。

  2.触发器的种类

  SQL Server 2000 支持两种类型的触发器:AFTER 触发器和INSTEAD OF 触发器。其中AFTER 触发器即为SQL Server 2000 版本以前所介绍的触发器。该类型触发器要求只有执行某一操作(Insert Update Delete) 之后,触发器才被触发,且只能在表上定义。可以为针对表的同一操作定义多个触发器。对于AFTER 触发器,可以定义哪一个触发器被最先触发,哪一个被最后触发,通常使用系统过程sp_settriggerorder 来完成此任务。

  INSTEAD OF 触发器表示并不执行其所定义的操作(Insert、 Update、 Delete),而仅是执行触发器本身。既可在表上定义INSTEAD OF 触发器,也可以在视图上定义INSTEAD OF 触发器,但对同一操作只能定义一个INSTEAD OF 触发器。





带有输出参数的存储过程(返回前两条记录的ID的和)

CREATE PROCEDURE mysp_output
@ouput_name varchar(20) output
as select @ouput_name=columnName from tableName
go
执行:
declear @name varchar(20)
exec mysp_output @name output
select @name as name
分享到:
评论

相关推荐

    SQL存储过程试题及答案

    SQL存储过程试题及答案 SQL存储过程是数据库中的一种程序单元,能够完成特定的数据库操作。今天,我们将讨论三道关于SQL存储过程的试题,这些试题涵盖了存储过程的创建、调用和参数传递等方面。 1. 创建分数存储...

    SQL存储过程实例.doc

    SQL存储过程是数据库管理系统中一组为了完成特定功能的SQL语句集,它可以被命名并保存,然后在需要的时候调用,极大地提高了SQL代码的重用性和执行效率。在这个实例中,我们看到一个名为`Sum_wage`的存储过程,它的...

    SQL 存储过程发送HTTP请求

    ### SQL存储过程发送HTTP请求知识点解析 在数据库管理和应用程序开发中,经常需要实现数据库与外部系统之间的交互。其中一种常见的需求就是从SQL Server中的存储过程发起HTTP请求来获取或发送数据。这种技术不仅...

    学习sql存储过程的心得

    SQL存储过程是数据库管理系统中一组为了完成特定功能的SQL语句集合,它们被预先编译并存储在数据库中,可以通过一个名称来调用执行。学习SQL存储过程是提升数据库管理和应用开发效率的关键步骤,它可以帮助我们更好...

    delphi如何调用sql存储过程,并获取结果

    在Delphi中调用SQL存储过程并获取结果是数据库编程中的一个重要环节。下面将通过给定的代码示例,详细解析Delphi如何调用SQL存储过程,并获取执行结果。 ### Delphi调用SQL存储过程的基本步骤 #### 1. 准备工作 ...

    使用SQL存储过程发送邮件

    ### 使用SQL存储过程发送邮件 在数据库管理与应用开发中,常常需要利用SQL存储过程来实现复杂的业务逻辑或数据处理任务。本篇文章将详细介绍如何利用SQL Server中的存储过程实现发送邮件的功能,这对于需要进行自动...

    sql存储过程帮助文档

    SQL存储过程是数据库管理系统中一组为了完成特定功能的SQL语句集合,它们被编译并存储在数据库中,用户可以通过调用这个存储过程来执行预定义的任务,而不是每次需要时都编写相同的SQL代码。这个“sql存储过程帮助...

    SQL存储过程SQL存储过程SQL存储过程

    SQL存储过程详解 SQL存储过程是数据库管理系统中的一种重要组件,它是一组为了完成特定功能的 SQL 语句,集经编译后存储在数据库中,用户通过指定存储过程的名字并给出参数来执行它。本文将对 SQL存储过程进行详细...

    原创sql存储过程函数范例

    原创sql存储过程函数范例,一是为了自己方便查找,今天到公司因为没有我保存的一些范例,一个简单的例子写了半个小时,如果有范例直接套几分钟肯定搞定,所以索性上传到CSDN上,何时何地都能找到我的范例了。...

    Sql存储过程格式

    ### SQL存储过程格式详解 SQL存储过程是一种预编译的SQL语句集合,可以在数据库中创建并保存,供外部程序调用。它们提供了一种封装和重用代码的方法,可以包含复杂的逻辑流程控制,如循环、条件判断等,从而增强...

    在SQL存储过程中进行参数数组Array Parameter的处理函数

    以下将详细讲解如何在SQL存储过程中处理参数数组。 1. **使用Table-Valued Parameters (TVP)** TVP是SQL Server 2008引入的一种特性,它允许我们传递一个表格结构的数据作为参数。首先,我们需要定义一个用户定义...

    sql存储过程学习,详细的解说存储过程的语法,结构和用法。

    SQL存储过程是数据库管理系统中的一种重要工具,它允许程序员和数据库管理员预先定义并存储一系列复杂的SQL语句,以便后续调用。存储过程不仅能够提高数据处理的效率,还能增强数据库的安全性和可维护性。以下是对...

    sql存储过程和触发器

    SQL存储过程和触发器是数据库管理系统中用于实现特定功能的重要工具,主要应用于SQL Server 2000等数据库系统。 存储过程(Stored Procedure)是一组预先编译的SQL语句集合,它们被存储在数据库中,可以被多次调用...

    sql server2008轻松编写t-sql存储过程

    本文将重点介绍如何在SQL Server 2008环境中轻松编写T-SQL存储过程,并通过具体的示例来展示其实现方法。 #### 二、SQL Server Management Studio (SSMS) 在SQL Server 2008中,SQL Server Management Studio ...

    sql 存储过程的学习 和实例

    SQL存储过程是数据库管理系统中一组为了完成特定功能的SQL语句集合,它们被编译并存储在数据库中,可以被多次调用,提高了代码的复用性和执行效率。本篇文章将深入探讨SQL存储过程的学习与实例,以帮助你更好地理解...

    sql存储过程

    在信息技术领域,尤其是在数据库管理系统中,SQL存储过程是一项重要技术。其核心价值在于能够让数据库管理员或者开发人员通过编写一段代码来封装一系列数据库操作,使得这些操作可以被重用、简化数据库操作流程,并...

    SQL存储过程解密

    标题与描述解析:“SQL存储过程解密”与“SQL Server加密存储过程解密,很好用。”这两句话共同指向了一个在IT领域尤其是数据库管理中的重要概念——如何解密SQL Server中的加密存储过程。在数据库管理系统(DBMS)...

    自动执行SQL语句&创建标准的Sql 存储过程

    在SQL数据库管理中,自动执行SQL语句和创建标准的SQL存储过程是两个重要的操作,它们对于数据库管理和数据处理有着深远的影响。以下是这两个主题的详细解释: 首先,自动执行SQL语句是指通过一定的机制,让预定义的...

Global site tag (gtag.js) - Google Analytics