1.什么是存储过程
存储过程是SQL语句和控制语句的预编译集合,保存在数据库里,可由应用程序调用执行,而且允许用户声明变量、逻辑控制语句及其他强大的编程功能。保存在SQLServer中,通过名称和参数执行,也可以返回结果。对于存储过程我更倾向于把他理解成方法。它里面可以只有一条查询语句,也可以包含一系列使用控制流的SQL语句。
2.为什么要使用存储过程
应用程序通过T-SQL语句到服务器的过程是不安全的。
1) 数据不安全
2)每次提交SQL代码都要经过语法编译后在执行,影响应用程序的运行性能
3) 网络流量大
3.存错过程的优缺点
(1) 优点
1) 模块化呈现设计
2) 执行速度快,效率高
3) 减少网络流量
4) 具有良好的安全性
(2) 缺点
1)不可移植性,每种数据库的内部编程语法都不太相同,当你的系统需要兼容多种数据库时最好不要用存储过程。
2)学习成本高,DBA一般都擅长写存储过程,但并不是每个程序员都能写好存储过程,除非你的团队有较多的开发人员熟悉 写存储过程,否则后期系统维护会产生问题。
3)业务逻辑多处存在,采用存储过程后也就意味着你的系统有一些业务逻辑不是在应用程序里处理,这种架构会增加一些系 统维护和调试成本。
4.实例
(1) 只返回单一记录集的存储过程,如图所示:
结果:相当于运行 select * from UserAccount 这行代码,结果为整个表的数据。
(2)没有输入输出的存储过程,如图所示:
结果:相当于运行 insert into UserAccount (UserName,[PassWord],RegisterTime,RegisterIP) values(9,9,'2013-01-02',9) 这行代码。
(3) 有返回值的存储过程,如图所示:
解释:这里的@@rowcount为执行存储过程影响的行数,执行的结果是不仅插入了一条数据,还返回了一个值即 return value =1 ,这个可以在程序中获取,稍后在c#调用存储过程中会有说到。
(4) 有输入参数和输出参数的存储过程,如图所示:
解释:@UserName为输入参数,@UserID为输出参数。 运行结果为@userID为COOUT(*)即 =1。
(5) 同时具有返回值、输入参数、输出参数的存储过程,如图所示:
结果:@userID为COOUT(*)即 =1,Retun Value=1。
(6) 同时返回参数和记录集的存储过程,如图所示:
结果:返回执行 select * from UserAccount 这句代码的结果集,同时@userID为COOUT(*)即 =1,Retun Value=9。
(7) 返回多个记录集的存储过程,如图所示:
结果:返回两个结果集,一个为 select * from UserAccount,另一个为 select * from UserAccount where UserID>5 。