sql 存储过程 入门级 练习

人生第一次写博客,想想都不知道写些什么!

初来乍到,就写写刚刚开始工作的时候遇到的第一次技术学习,虽然现在看来就是个笑话。

记得当时还是刚刚毕业,在公司才工作了一个多月吧,让我写一个存储过程。老实说,上学的时候也就是在大四的时候,学习了C#,其余的语言也学习了,但是学习的程度嘛··呵呵,大学啊,大家都懂的,都还给老师了。听到让我写个存储过程,心里是各种草泥马飘过啊,但是工作嘛,必须要迎头上。当时没做两分钟,因为什么都不懂,所以难免有点急躁,和同事说话的口气有点冲,还好大家都很理解我。然后是焦老板(我现在的舍友)教的我,当时我记得应该是写了有一个小时,呵呵。写的是什么现在倒是不记得了,但是应该是不难的。

好了,闲话少叙,下面进入正题。

1.打开你的sql service ,页面应该都是差不多的,我经常用的就2005 ,2008和2008R2


2.右键之后选择新建存储过程,出来的页面大概就是下面这个样子


3.一般来说,打开之后,1-11行,我基本是直接删除掉的,然后17,18,19行我每次是必写的,愿意是因为一个开发的不可能是你一个人做的,当然如果真的是你一个人开发,也要想到以后维护的事情,或者二期的人员不一定就有你了,所以在这里写上作者、日期和描述是相当重要的。21行的代码实际上就是你要写上你的存储过程名称,比如当然了,这里写的sp开头实际上是不怎么好的,因为可能会遇到后期优化sql,改善执行存储过程速度的问题,但这里先不管,有空也可以谢谢sql优化的文章。推荐的写法是不要sp开头。


一个存储过程的名字必须要让其他人一目了然,但是绝对不是用中文,中文是绝对禁止的,严格意义上来说在某些方面我们的确是落后一点,大家心里明白就好。

下面需要做的就是将传入的参数写好,下图只是简单举例,不强调写法。


个人建议还是加上注释最好,因为有的时候,参数多的情况下,你很容易就会混乱字段的意义,尤其是财务项目相关的时候,那叫一个操蛋。题外话,刚刚工作第一个月就是做的测试财务的项目,真是各种草泥马。

接下来就是关键的部分了,修改select语句,当然你如果做update也可以直接删掉,重新写。


这个应该是最最简单的一个存储过程,仅仅一步插入。之后就可以可以直接按下F5,就创建成功了。

但是这边说的简单,可是sql的用法还是很强大的。本文仅仅是入门罢了,后面需要学习的还有许多,例如游标(这个应该相对来说难了一丢丢)。有空也可以写着玩。

写完了,有问题的话,欢迎来提。

第一次写,高手勿喷。我也仅仅是抱着游戏的心态写玩的。

存储过程Procedure是一组为了完成特定功能的SQL语句集合,经编译后存储在数据库中,用户通过指定存储过程的名称并给出参数来执行。 存储过程中可以包含逻辑控制语句和数据操纵语句,它可以接受参数、输出参数、返回单个或多个结果集以及返回值。 由于存储过程创建时即在数据库服务器上进行了编译并存储在数据库中,所以存储过程运行要比单个的SQL语句块要快。同时由于在调用时只需用提供存储过程名和必要的参数信息,所以在一定程度上也可以减少网络流量、简单网络负担。 1、 存储过程的优点 A、 存储过程允许标准组件式编程 存储过程创建后可以在程序中被多次调用执行,而不必重新编写该存储过程SQL语句。而且数据库专业人员可以随时对存储过程进行修改,但对应用程序源代码却毫无影响,从而极大的提高了程序的可移植性。 B、 存储过程能够实现较快的执行速度 如果某一操作包含大量的T-SQL语句代码,分别被多次执行,那么存储过程要比批处理的执行速度快得多。因为存储过程是预编译的,在首次运行一个存储过程时,查询优化器对其进行分析、优化,并给出最终被存在系统表中的存储计划。而批处理的T-SQL语句每次运行都需要预编译和优化,所以速度就要慢一些。 C、 存储过程减轻网络流量 对于同一个针对数据库对象的操作,如果这一操作所涉及到的T-SQL语句被组织成一存储过程,那么当在客户机上调用该存储过程时,网络中传递的只是该调用语句,否则将会是多条SQL语句。从而减轻了网络流量,降低了网络负载。 D、 存储过程可被作为一种安全机制来充分利用 系统管理员可以对执行的某一个存储过程进行权限限制,从而能够实现对某些数据访问的限制,避免非授权用户对数据的访问,保证数据的安全。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值