• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    sql存储过程详解

    1,不带参数的存储过程

    2,带输入参数的存储过程

    3,带输入和输出参数的存储过程

    4,带返回值的存储过程

    不带参数的存储过程

    例如,以下存储过程返回Employees表中所有职员的记录。

    存储过程代码:

    USE TSQLFundamentals2008;
    GO
    
    IF OBJECT_ID('usp_ProcDemoNoParam','P') IS NOT NULL DROP PROC usp_ProcDemoNoParam;
    GO
    -- 1,不带参数
    CREATE PROC usp_ProcDemoNoParam
    AS
    BEGIN
      SELECT * FROM HR.Employees;
    END
    GO
    
    

    调用代码:

    USE TSQLFundamentals2008;
    GO
    
    -- 1,不带参数存储过程的调用
    EXEC usp_ProcDemoNoParam;
    
    

    结果:

    可以看到,共返回了9条记录。

    带输入参数的存储过程

    例如,该存储过程接受输入参数@empid,然后返回这个职员的信息。

    创建存储过程代码:

    IF OBJECT_ID('usp_ProcDemoWithInputParam','P') IS NOT NULL DROP PROC usp_ProcDemoWithInputParam;
    GO
    -- 2,带输入参数
    CREATE PROC usp_ProcDemoWithInputParam
      @empid AS INT
    AS
    BEGIN
      SELECT * FROM HR.Employees
      WHERE empid= @empid;
    END
    GO
    
    

    调用:

    -- 2,带输入参数存储过程调用
    EXEC usp_ProcDemoWithInputParam @empid=5;
    

    结果:

    带输入和输出参数的存储过程

    例如,以下存储过程接受@empid即职员ID作为输入参数,然后返回该职员的信息,同时返回代码受影响行数作为输出参数。

    创建存储过程代码:

    IF OBJECT_ID('usp_ProcDemoWithInputOutputParam','P') IS NOT NULL DROP PROC usp_ProcDemoWithInputOutputParam;
    GO
    -- 3,带输入和输出参数
    CREATE PROC usp_ProcDemoWithInputOutputParam
      @empid AS INT,
      @NumRowsAffected AS INT OUTPUT
    AS
    BEGIN
      SELECT * FROM HR.Employees
      WHERE empid= @empid;
      
      SET @NumRowsAffected= @@ROWCOUNT; -- 赋值,也可以使用select赋值
    END
    GO
    
    

    调用:

    -- 3,带输入和输出参数存储过程的调用
    DECLARE @nums AS INT;
    EXEC usp_ProcDemoWithInputOutputParam @empid=5,@NumRowsAffected= @nums OUTPUT;
    SELECT @nums AS nums;
    

    结果:

    带返回值的存储过程

    例如,以下存储过程接受@empid即职员ID作为输入参数,然后判断职员表中是否存在该职员的记录,如果存在则返回1,否则返回0.

    创建存储过程代码:

    IF OBJECT_ID('usp_ProcDemoWithReturnValue','P') IS NOT NULL DROP PROC usp_ProcDemoWithReturnValue;
    GO
    -- 4,带返回值
    CREATE PROC usp_ProcDemoWithReturnValue
      @empid AS INT
    AS
    BEGIN
      IF EXISTS (SELECT * FROM HR.Employees WHERE empid=@empid)
        RETURN 1
      ELSE
        RETURN 0; -- 也可以声明一个变量,然后返回这个变量
    END
    GO
    
    

    调用:

    -- 4,带返回值存储过程的调用
    DECLARE @status AS INT=0; --给默认值为0
    EXEC @status= dbo.usp_ProcDemoWithReturnValue @empid = 5 -- int
    SELECT @status AS thestatus;
    

    结果:

    您可能感兴趣的文章:
    • mssql使用存储过程破解sa密码
    • MSSQL监控数据库的DDL操作(创建,修改,删除存储过程,创建,修改,删除表等)
    • PHP得到mssql的存储过程的输出参数功能实现
    • MSSQL MySQL 数据库分页(存储过程)
    • mssql存储过程表名和字段名为变量的实现方法
    • MSSQL存储过程学习笔记一 关于存储过程
    • 实例学习mssql存储过程分析
    • MySQL 存储过程中执行动态SQL语句的方法
    • sqlserver存储过程语法详解
    • MSSQL事务的存储过程
    上一篇:总结一周内学习的Sql经验(一)
    下一篇:SQL Server UPDATE语句的用法详解
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    sql存储过程详解 sql,存储,过程,详解,sql,存储,