zoukankan      html  css  js  c++  java
  • 存储过程

    什么是存储过程呢?
    存储过程就是作为可执行对象存放在数据库中的一个或多个SQL命令。
    通俗来讲:存储过程其实就是能完成一定操作的一组SQL语句。

    那为什么要用存储过程呢?
    1.存储过程只在创造时进行编译,以后每次执行存储过程都不需再重新编译,而一般SQL语句每执行一次就编译一次,所以使用存储过程可提高数据库执行速度。
    2.当对数据库进行复杂操作时,可将此复杂操作用存储过程封装起来与数据库提供的事务处理结合一起使用。
    3.存储过程可以重复使用,可减少数据库开发人员的工作量。
    4.安全性高,可设定只有某些用户才具有对指定存储过程的使用权

    那存储过程怎么用呢?
    以下通过表Student 来了解存储过程,因为是要了解存储过程的简单用法,所以所有例子均很简单。

    无参数存储过程:
    选出Student表中的所有信息,

    create proc StuProc
    as //此处 as 不可以省略不写
    begin //begin 和 end 是一对,不可以只写其中一个,但可以都不写
    select S#,Sname,Sage,Ssex from student
    end
    go

    有参数存储过程:
    全局变量
    全局变量也称为外部变量,是在函数的外部定义的,它的作用域为从变量定义处开始,到本程序文件的末尾。
    选出指定姓名的学生信息:

    复制代码
    create proc StuProc
    @sname varchar(100)
    as
    begin
    select S#,Sname,Sage,Ssex from student where sname=@sname
    end
    go

    exec StuProc '赵雷' //执行语句
    复制代码

    上面是在外部给变量赋值,也可以在内部直接给变量设置默认值

    复制代码
    create proc StuProc
    @sname varchar(100)='赵雷'
    as
    begin
    select S#,Sname,Sage,Ssex from student where sname=@sname
    end
    go

    exec StuProc
    复制代码

    也可以把变量的内容输出,使用output

    复制代码
    create proc StuProc
    @sname varchar(100),
    @IsRight int output //传出参数
    as
    if exists (select S#,Sname,Sage,Ssex from student where sname=@sname)
    set @IsRight =1
    else
    set @IsRight=0
    go

    declare @IsRight int
    exec StuProc '赵雷' , @IsRight output
    select @IsRight
    复制代码

    以上是全局变量,下面来了解局部变量
    局部变量也称为内部变量。局部变量是在函数内作定义说明的。其作用域仅限于函数内部,离开该函数后再使用这种变量是非法的。
    局部变量的定义:必须先用Declare命令定以后才可以使用,declare{@变量名 数据类型}
    局部变量的赋值方法:set{@变量名=表达式}或者select{@变量名=表达式}
    局部变量的显示:select @变量名

    复制代码
    create proc StuProc
    as
    declare @sname varchar(100)
    set @sname='赵雷'
    select S#,Sname,Sage,Ssex from student where sname=@sname
    go

    exec StuProc
    复制代码

    那如果是要把局部变量的数据显示出来怎么办呢?

    复制代码
    create proc StuProc
    as
    declare @sname varchar(100)
    set @sname=(select Sname from student where S#=01)
    select @sname
    go

    exec StuProc
     
     
     

    带输出参数存储过程

    if (object_id('proc_getStudentRecord', 'P') is not null)
    drop proc proc_getStudentRecord
    go
    create proc proc_getStudentRecord(
    @id int, --默认输入参数
    @name varchar(20) out, --输出参数
    @age varchar(20) output--输入输出参数
    )
    as
    select @name = name, @age = age from student where id = @id and sex = @age;
    go

     
    复制代码
     

    本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,并在文章页面明显位置以超链接形式注明出处,否则保留追究法律责任的权利。

    http://www.cnblogs.com/jiajiayuan/archive/2011/06/15/2081201.html

  • 相关阅读:
    【原】从/dev/null重新打开标准输出
    Go 接口转换的一个例子
    关于软件编译安装的出错处理
    【原】GO 语言常见错误
    HP平台由于变量声明冲突导致程序退出时的core
    动态链接库加载出错:cannot restore segment prot after reloc: Permission denied
    Windows VC++常见问题汇总
    .net:System.Web.Mail vs System.Net.Mail应该用哪个
    网络管理的功能
    Hello World! — 用 Groovy 编写的 Java 程序
  • 原文地址:https://www.cnblogs.com/panmy/p/5222995.html
Copyright © 2011-2022 走看看