亦有资源网

C++语言基础到进阶学习资源汇总

数据库基础知识:SQL Server存储过程入门必知

什么是存储过程

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

存储过程语法

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 存储过程名

用户变量的传递

存储过程中使用用户变量

 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:该类型数据综合了上述两种类型的特点,可以传入也可以被修改

FOUND_ROWS()和row_count()

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

存储过程的好处

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

课后练习

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

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

控制面板
您好,欢迎到访网站!
  查看权限
网站分类
最新留言