• 技术文章 >数据库 >SQL

    浅谈数据库的存储过程

    步履不停步履不停2020-09-12 14:54:54原创26198

    什么是存储过程

    如果你接触过其他的编程语言,那么就好理解了,存储过程就像是方法一样。

      竟然他是方法那么他就有类似的方法名,方法要传递的变量和返回结果,所以存储过程有存储过程名有存储过程参数也有返回值。

      存储过程的优点:

    存储过程可以分为系统存储过程、扩展存储过程和用户自定义的存储过程

    系统存储过程

    我们先来看一下系统存储过程,系统存储过程由系统定义,主要存放在MASTER数据库中,名称以"SP"开头或以"XP"开头。尽管这些系统存储过程在MASTER数据库中,

      但我们在其他数据库还是可以调用系统存储过程。有一些系统存储过程会在创建新的数据库的时候被自动创建在当前数据库中。

    常用系统存储过程有:

    存储过程语法:

    在创建一个存储过程前,先来说一下存储过程的命名,看到好几篇讲存储过程的文章都喜欢在创建存储过程的时候加一个前缀,养成在存储过程名前加前缀的习惯很重要,虽然这只是一件很小的事情,但是往往小细节决定大成败。看到有的人喜欢这样加前缀,例如proc_名字。也看到这加样前缀usp_名字。前一种proc是procedure的简写,后一种sup意思是user procedure。我比较喜欢第一种,那么下面所有的存储过程名都以第一种来写。至于名字的写法采用骆驼命名法。

    创建存储过程的语法如下:

    CREATE PROC[EDURE] 存储过程名 
    
    @参数1 [数据类型]=[默认值] [OUTPUT] 
    
    @参数2 [数据类型]=[默认值] [OUTPUT]
    
    AS 
    
    SQL语句
    
    EXEC 过程名[参数]

    使用存储过程实例:

    1.不带参数

    create procedure proc_select_officeinfo--(存储过程名)as select Id,Name from Office_Info--(sql语句)
    
    exec proc_select_officeinfo--(调用存储过程)

    2.带输入参数

    create procedure procedure_proc_GetoffinfoById ----  Name  dbo.Office_Info  Id=@Id----(存储过程名称之后,空格加上参数,多个参数中间以逗号分隔)
    
    注:参数赋值是,第一个参数可以不写参数名称,后面传入参数,需要明确传入的是哪个参数名称

    3.带输入输出参数

    create procedure proc_office_info--(存储过程名)
    @Id int,@Name varchar(20) output--(参数名 参数类型)传出参数要加上output
    as
    begin
    select @Name=Name from dbo.Office_Info where Id=@Id --(sql语句)
    end

    declare @houseName varchar(20) --声明一个变量,获取存储过程传出来的值
    exec proc_office_info--(存储过程名)
    4,@houseName output--(传说参数要加output 这边如果用@变量 = OUTPUT会报错,所以换一种写法)

    select @houseName--(显示值)

    4.带返回值的

    create procedure proc_office_info--(存储过程名)
    @Id int--(参数名 参数类型)as beginif(select Name from dbo.Office_Info where Id=@Id)=null --(sql语句)
    beginreturn -1endelsebeginreturn 1end
    end
    
    declare @house varchar(20) --声明一个变量,获取存储过程传出来的值
    exec @house=proc_office_info 2 --(调用存储过程,用变量接收返回值)--注:带返回值的存储过程只能为int类型的返回值
    print @house

    更多SQL的相关技术文章,请访问SQL教程栏目进行学习!

    以上就是浅谈数据库的存储过程的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:数据库 存储过程
    上一篇:数据库存储过程详解 下一篇:数据库添加语句是什么

    相关文章推荐

    • PHP存储过程实例分析• 数据库存储过程怎么写• 数据库存储过程详解

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网