sqlcommand 执行多个储存过程是报错_数据库基础知识:SQL Server存储过程入门必知...

4bd7e4b61a3d104afcb88d595c0f9c0b.png

什么是存储过程

a845dc7120ddc213fe0f59b3844f9975.png

SQL语句需要先编译然后执行,而存储过程(Stored Procedure)是一组为了完成特定功能的SQL语句集,经编译后存储在数据库中,用户通过指定存储过程的名字并给定参数(如果该存储过程带有参数)来调用执行它。

存储过程语法

0d75d9a195a2cb418d55c7c67c13bf8d.png

CREATE PROCEDURE 过程名([[IN|OUT|INOUT] 参数名 数据类型[,[IN|OUT|INOUT] 参数名 数据类型…]]) [特性 ...] 过程体

DELIMITER //
   CREATE PROCEDURE myproc(OUT s int)
   BEGIN  
   SELECT COUNT(*) INTO s FROM students;
   SELECT COUNT(*) INTO s FROM students;
   SELECT COUNT(*) INTO s FROM students;
   END
   //
   DELIMITER ;

MySQL默认以";"为分隔符,如果没有声明分割符,则编译器会把存储过程当成SQL语句进行处理,因此编译过程会报错,所以要事先用“DELIMITER //”声明当前段分隔符,让编译器把两个"//"之间的内容当做存储过程的代码,不会执行这些代码;“DELIMITER ;”的意为把分隔符还原。

调用方式:call 存储过程名称 - 删除方式:drop procedure 存储过程名

用户变量的传递

f72f22a572e272fff4e878945aa0a3f3.png

存储过程中使用用户变量

create procedure cd1() select concat(@hl,'world');
 set @hl='Hello ';
 call cd1();

储存过程之间传递用户变量 create procedure cd21() set @name = 'join'; create procedure cd22() select @name; call cd22(); call cd21(); call cd22();

注意:滥用用户变量会导致程序难以理解及管理

参数类型

in:in类型的参数,存储过程中的代码对其进行的修改并不会影响该变量实际的值,属于有去无回 - out:out类型参数,用于输出值,会忽略传入的值。在子程序内部可以对其进行修改。 - inout:该类型数据综合了上述两种类型的特点,可以传入也可以被修改

76065cf7f0512997666b39418b5e97ce.png

FOUND_ROWS()和row_count()

FOUND_ROWS():上次查询的结果的行数 - row_count():上次增删改影响的行数 - select last_insert_id():获取上一次自动增长的id

存储过程的好处

19858f47d68219090be9a1386fb8684a.png

执行速度快 - 允许模块化程序设计 - 提高系统的安全性 - 减少网络流量

课后练习

账户【id,用户名,密码,钱数】,日志【id,描述】两个表

写一个存储过程输入参数3个,一个输出参数,用户名,密码,初始金额,用于办卡,生成一条用户名系,并将此记录到日志表中。【1,id:1办卡成功】 - 写一个存储过程参数一个uname,输出参数一个varchar类型,根据该用户的钱数判断,是土豪或者不是【>10000是土豪】,将结果以输出参数的方式传出

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值