mysql存储过程

mysql存储过程:

解释:

是在大型数据库为了完成一组特定功能的SQL语句集,经编译后存储在数据库中,用户通过指定存储过程的名字并给出参数:。

优点:

1.执行速度更快 – 在数据库中保存的存储过程语句都是编译过的

  2.允许模块化程序设计 – 类似方法的复用

  3.提高系统安全性 – 防止SQL注入

  4.减少网络流通量 – 只要传输存储过程的名称

简单案例:

下面案例是我在navicat实现的:

CREATE DEFINER=`root`@`localhost` PROCEDURE `insert`(IN `uid` int)
BEGIN
#Routine body goes here...
 insert into article(uid,title,content,created_at) values(uid,'你好','谢谢',NOW());

 insert into posts(uid,title,content,created_at) values(uid,'你好','谢谢',NOW());

END

定义存储过程:  

create proc usp_StudentByGenderAge

  @gender nvarchar(10) [='男'],

  @age int [=30]

  as

  select * from MyStudent where FGender=@gender and FAge=@age

  执行存储过程:

  Situation One(调用默认的参数):

 exec usp_StudentByGenderAge

  Situation Two(调用自己指定的参数):

  exec usp_StudentByGenderAge '女',50

  或者指定变量名      

   exec usp_StudentByGenderAge @age=50,@gender='女'

  对存储过程进行修改,

alter proc usp_StudentByGenderAge

  @gender nvarchar(10) [='男'],

  @age int [=30]

  --加output表示该参数是需要在存储过程中赋值并返回的 

 @recorderCount int output 

  as

  select * from MyStudent where FGender=@gender and FAge=@age

  set @recorderCount=(select count(*) from MyStudent where FGender=@gender and FAge=@age)

--output参数的目的,就是调用者需要传递一个变量进来,然后在存储过程中为该变量完成赋值工作,存储过程执行完成以后,将执行的对应结果返回给传递进来的变量。(与C#中的out原理一模一样)

调用(记住这里的语法!)因为该存储过程前面还有其他参数,所以要把 @recorderCount写上,该存储过程执行后,相当与完成了以上的查询工作,同时将查询结果得到的条数赋值给了@count变量。(@count是当做参数传给usp_StudentByGenderAge,当存储过程执行完毕以后,将得到的条数返回给@count)  

declare @count int

  exec usp_StudentByGenderAge @recorderCount=@count output

  print @count

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值