SQL存储过程全面实例讲解38317.pdf
《SQL存储过程全面实例讲解38317.pdf》由会员分享,可在线阅读,更多相关《SQL存储过程全面实例讲解38317.pdf(6页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、-.z.SQL 实例讲解 一、创建存储过程结构 CREATEPROCEDURE 创建存储过程,存储过程是保存起来的可以接受和返回用户提供的参数的 Transact-SQL 语句的集合。可以创建一个过程供永久使用,或在一个会话中临时使用(局部临时过程),或在所有会话中临时使用(全局临时过程)。也可以创建在 MicrosoftSQLServer 启动时自动运行的存储过程。语法 CREATEPROCEDUREprocedure_name;numberparameterdata_typeVARYING=defaultOUTPUT,.n WITHREPILE|ENCRYPTION|REPILE,ENCR
2、YPTION FORREPLICATION ASsql_statement.n 二、存储过程实例讲解 1.使用带有复杂 SELECT 语句的简单过程下面的存储过程从四个表的联接中返回所有作者(提供了*)、出版的书籍以及。该存储过程不使用任何参数。USEpubs IFE*ISTS(SELECTnameFROMsysobjectsWHEREname=au_info_allANDtype=P)DROPPROCEDUREau_info_all GO CREATEPROCEDUREau_info_all AS SELECTau_lname,au_fname,title,pub_nameFROMautho
3、rsaINNERJOINtitleauthortaONa.au_id=ta.au_idINNERJOINtitlestONt.title_id=ta.title_idINNERJOINpublisherspONt.pub_id=p.pub_id GOau_info_all 存储过程可以通过以下方法执行:E*ECUTEau_info_all-Or E*ECau_info_all 如果该过程是批处理中的第一条语句,则可使用:au_info_all2.使用带有参数的简单过程下面的存储过程从四个表的联接中只返回指定的作者(提供了*)、出版的书籍以及。该存储过程接受与传递的参数精确匹配的值。USEpub
4、s IFE*ISTS(SELECTnameFROMsysobjectsWHEREname=au_infoANDtype=P)DROPPROCEDUREau_info GO USEpubsGO CREATEPROCEDUREau_infolastnamevarchar(40),firstnamevarchar(20)AS SELECTau_lname,au_fname,title,pub_nameFROMauthorsaINNERJOINtitleauthortaONa.au_id=ta.au_idINNERJOINtitlestONt.title_id=ta.title_idINNERJOIN
5、publisherspONt.pub_id=p.pub_idWHEREau_fname=firstnameANDau_lname=lastname GOau_info 存储过程可以通过以下方法执行:E*ECUTEau_infoDull,Ann-Or-.z.E*ECUTEau_infolastname=Dull,firstname=Ann-Or E*ECUTEau_infofirstname=Ann,lastname=Dull-Or E*ECau_infoDull,Ann-Or E*ECau_infolastname=Dull,firstname=Ann-Or E*ECau_infofirstn
6、ame=Ann,lastname=Dull如果该过程是批处理中的第一条语句,则可使用:au_infoDull,Ann-Orau_infolastname=Dull,firstname=Ann-Orau_infofirstname=Ann,lastname=Dull3.使用带有通配符参数的简单过程下面的存储过程从四个表的联接中只返回指定的作者(提供了*)、出版的书籍以及。该存储过程对传递的参数进行模式匹配,如果没有提供参数,则使用预设的默认值。USEpubs IFE*ISTS(SELECTnameFROMsysobjectsWHEREname=au_info2ANDtype=P)DROPPROC
7、EDUREau_info2 GO USEpubs GO CREATEPROCEDUREau_info2lastnamevarchar(30)=D*,firstnamevarchar(18)=*AS SELECTau_lname,au_fname,title,pub_name FROMauthorsaINNERJOINtitleauthortaONa.au_id=ta.au_idINNERJOINtitlestONt.title_id=ta.title_idINNERJOINpublisherspONt.pub_id=p.pub_id WHEREau_fnameLIKEfirstnameANDa
8、u_lnameLIKElastname GO au_info2 存储过程可以用多种组合执行。下面只列出了部分组合:E*ECUTEau_info2-Or E*ECUTEau_info2Wh*-Or E*ECUTEau_info2firstname=A*-Or E*ECUTEau_info2CKarsOEn-OrE*ECUTEau_info2Hunter,Sheryl-Or E*ECUTEau_info2H*,S*4.使用 OUTPUT 参数 OUTPUT 参数允许外部过程、批处理或多条 Transact-SQL 语句访问在过程执行期间设置的*个值。下面的示例创建一个存储过程(titles_sum
9、),并使用一个可选的输入参数和一个输出参数。首先,创建过程:USEpubs GOIFE*ISTS(SELECTnameFROMsysobjectsWHEREname=titles_sumANDtype=P)DROPPROCEDUREtitles_sum GO-.z.USEpubs GO CREATEPROCEDUREtitles_sumTITLEvarchar(40)=*,SUMmoneyOUTPUT AS SELECTTitleName=title FROMtitles WHEREtitleLIKETITLE SELECTSUM=SUM(price)FROMtitles WHEREtitle
10、LIKETITLE GO 接下来,将该 OUTPUT 参数用于控制流语言。说明 OUTPUT 变量必须在创建表和使用该变量时都进行定义。参数名和变量名不一定要匹配,不过数据类型和参数位置必须匹配(除非使用 SUM=variable 形式)。DECLARETOTALCOSTmoney E*ECUTEtitles_sumThe*,TOTALCOSTOUTPUT IFTOTALCOST200 BEGINPRINTPRINTAllofthesetitlescanbepurchasedforlessthan$200.END ELSESELECTThetotalcostofthesetitlesis$+R
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- SQL 存储 过程 全面 实例 讲解 38317
限制150内