当前位置:  数据库>sqlserver

实例学习mssql存储过程分析

    来源: 互联网  发布时间:2014-09-05

    本文导语:  例1:通过存储过程查询数据库中的student表   我们知道在sql中,我们查询一个表,可以通过 select * from student  进行查询,那在存储过程中该怎么写呢?   解:   首先我们打开查询分析器,(以下举的例子中的存储过程...

例1:通过存储过程查询数据库中的student表
  我们知道在sql中,我们查询一个表,可以通过 select * from student  进行查询,那在存储过程中该怎么写呢?
  解:
  首先我们打开查询分析器,(以下举的例子中的存储过程都用查询管理器来创建);  
  然后我们先来创建一个存储过程以备等会使用,(就好像在编程中我们先来编一个函数一样):
  create procedure proc_stu
  as
  select * from student
go
  这样一个存储过程就创建好了,现在我们来执行一下
  我们可以在查询分析器中输入:execute proc_stu 便可以看到效果
分析一下上面的例子,proc_stu为存储过程名,select * from student很显然就是SQL语句了,执行的时候我们只需要execute(执行) 存储过程名,就可以了.其中 , procedure 和 execute 可以分别缩写为 proc 和 exec 

  以上演示了一个很简单的存储过程.下面我们来看一下带参数的存储过程
  例2.查询student表中sno(学号)为 ' s1 '的记录
  create proc proc_stu
  @ ssno varchar(10)
as
select * from student where sno = @ ssno
go
这样一个带参数的存储过程就OK了,"@ 变量名"是sql 中用来表示用户自定义的参数的方法,有些朋友可能还看到过"@@变量名",这个是系统自带的.也就是说这个变量名是系统定义的,不能随便乱改.这样分析后,相信大家应该看得懂了吧.
  执行带参数的存储过程,需要使用如下语句:exec proc_stu s1 也可以不写参数,不过这样的话,必须首先在创建存储过程中加参数赋值,可以赋Null,否则,系统会报错.

  最后我们来讲一下如何利用存储过程返回一个值:
  例3.返回student表中学生数
方法一:(使用外部变量output)
  create proc proc_stu
@ num int output  --注明是外部变量
as
select  @ num = count ( * )  from student
go
  现在我们来执行下:
  要使用外部变量,我们先要进行声明:declare @ return我们用这个变量来接收存储过程中的外部变量
  execute  proc_stu  ,  @ num = @  return output
这样我们便得到了这个返回值,现在我们通过如下赋值语句来显示这个返回值
select  ' return '  =  @  return

  方法二(使用return):
注:return 只能返回整形数据
  create proc proc_stu
  @ num int
as
select  @ num = count ( * )  from student
return  @ num
go
我们来执行下:
  declare @ return
exec @ return = proc_stu
select  ' return '  = @ return


    
 
 

您可能感兴趣的文章:

  • mysql 存储过程实例和基本语法
  • oracle的存储过程实例讲解
  • oracle分页存储过程 oracle存储过程实例
  • MySQL 有输入输出参数的存储过程实例
  • mysql存储过程实例
  • Sql Server中存储过程中输入和输出参数(简单实例 一看就懂)
  • sqlserver 存储过程中If Else的用法实例
  • mysql存储过程中使用游标的实例
  • php curl存储cookie实例
  • Oracle存储过程返回游标实例详解
  • C 创建链表并将信息存储在二进制文件中读取的实例代码
  • Oracle存储过程之数据库中获取数据实例
  • .net二进制形式存储文件与图片的实例代码
  • SQL Server存储过程生成insert语句实例
  • java调用Oracle存储过程的方法实例
  • sql server 高效分页存储过程实例
  • mssql存储过程破解sa密码实例代码
  • SqlServer获取存储过程返回值的实例
  • MySQL存储过程使用实例详解
  • PHP用mysql数据库存储session实例解析
  • 2分法分页存储过程脚本实例
  • C#制作鹰眼的详细全过程(带注释)实例代码
  • 通过Android trace文件分析死锁ANR实例过程
  • Oracle 存储过程发送邮件实例学习
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • 使用libpcap读取tcpdump抓取的文件并解析c代码实例
  • 可以有其他两个类的实例同时调用一个java实例的两个方法吗?
  • Bean的作用域及Spring 暴露 Bean实例的方法介绍
  • 请问:类的实例化是怎么一回事?如何进行实例化?
  • Python 3 Tkinter教程之事件Event绑定处理代码实例
  • 万般火急!关于java打印,已经得到printerJob实例,那么怎么通过它得到Pageable实例?
  • Python namedtuple(命名元组)使用实例
  • 类的方法和实例方法,类字段和实例字段有什么不同,在使用上?
  • boost库区间range基本原理及使用实例
  • 既然在定义实例变量的时候可以初始化实例变量的值,那还要构造函数干吗?谢谢!
  • php session_id()函数介绍及代码实例
  • 怎么样判断一个类是否已经被实例化,并关闭这个实例,而且保证系统不退出(详情见内)
  • .NET下 c#通过COM组件操作并导出Excel实例代码
  • 请问在一个servlet里取得一个用singleton模式实现的类实例,那么这个类实例的生命周期是怎样的?
  • Sql Server中存储过程中输入和输出参数(简单实例 一看就懂) iis7站长之家
  • C#静态变量与实例变量实例分析
  • Mysql Select查询执行流程介绍及实例
  • 实例变量和类变量
  • c++类库Boost::bimap(双向映射)介绍及使用实例
  • 又谁能告诉我实例因该怎么去理解它?????????/
  • OpenStack中compute介绍和compute实例需要注意的问题
  • Keepalived 能配两个虚拟ip吗,匹配两个数据库实例?


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3