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

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

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

    无参数存储过程:
    选出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

    局部变量也称为内部变量。局部变量是在函数内作定义说明的。其作用域仅限于函数内部,离开该函数后再使用这种变量是非法的。
    局部变量的定义:必须先用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

    USE [TRAPP]
    GO
    /****** Object:  StoredProcedure [dbo].[P_TF_InitForm]    Script Date: 11/10/2014 4:49:26 PM ******/
    SET ANSI_NULLS ON
    /******SET ANSI_NULLS ON 以后, NULL = NULL 将 返回 false 如何注释
    GO
    SET QUOTED_IDENTIFIER ON
    GO
    
    
    ALTER PROCEDURE
    /******如果你要重新定义一个procedure A,如果A 已经被 procedure B用到了,如果你要用create去修改A,你必须先drop A,但是A被B引用,不能给drop。所以要用alter
        [dbo].[P_TF_InitForm]
    (
        @FormKey    varchar(10)
    )
    AS
    SET NOCOUNT ON
    
    declare
        @i        int,
        @FormType    varchar(5),
        @FormYr        smallint,
        @FormSr        varchar(5),
        @FormNo1    int,
        @FormNo2    int,
        @Company    varchar(10)
    
    
    select
        @FormYr = FormYr,
        @FormSr = FormSr,
        @FormNo1 = FormNoBeg,
        @FormNo2 = FormNoEnd,
        @FormType = FormType,
        @Company = Company
    --select *
    from
        U_TF_FormMaster    
    where
        FormKey = @FormKey and
        XCrt in ('0','')
    
    if @FormYr is null
        return -6
    
    set    @i    = @FormNo1
    while @i <= @FormNo2 begin
        insert into
            U_TF_PrintedForm
        (
            FormYr,
            FormSr,
            FormNo,
            FormType,
            FormKey,
            Company
        )
        values (
            @FormYr,
            @FormSr,
            @i,
            @FormType,
            @FormKey,
            @Company
        )
        set    @i    = @i + 1
    end
    
    update
        U_TF_FormMaster
    set
        XCrt = '1'
    where
        FormKey = @FormKey
        
    SET NOCOUNT OFF
  • 相关阅读:
    easyui tree loader用法
    mysql字符集
    mysql 内连接 左连接 右连接 外连接
    mysql 聚集函数和分组
    mysql 大数据量求平均值
    C++ 纯虚方法
    Windows xcopy
    服务端数据库的操作如何不阻塞
    分布式系统业务服务器的设计
    mysql 查询执行的流程
  • 原文地址:https://www.cnblogs.com/chrisghb8812/p/6089401.html
Copyright © 2011-2022 走看看