{"id":264,"date":"2010-05-07T17:25:12","date_gmt":"2010-05-07T09:25:12","guid":{"rendered":"http:\/\/blog.infinity.idv.tw\/index.php\/2010\/05\/07\/sql-%e9%a0%90%e5%ad%98%e7%a8%8b%e5%ba%8f-stored-procedures\/"},"modified":"2011-03-22T16:08:42","modified_gmt":"2011-03-22T08:08:42","slug":"sql-%e9%a0%90%e5%ad%98%e7%a8%8b%e5%ba%8f-stored-procedures","status":"publish","type":"post","link":"http:\/\/blog.infinity.idv.tw\/?p=264","title":{"rendered":"SQL \u9810\u5b58\u7a0b\u5e8f Stored Procedures"},"content":{"rendered":"<p><b>\u4e00\u76f4\u90fd\u4e0d\u77e5\u5230\u5565\u662f\u9810\u5b58\u7a0b\u5e8f\uff0c\u5f8c\u4f86\u5927\u6982\u77e5\u9053\u5b83\u662f\u505a\u4ec0\u9ebc\u7528\u7684\uff0c\u76f4\u5230\u73fe\u5728\u624d\u958b\u59cb\u9762\u5c0d\u5b83\uff0c\u5927\u6982\u4e86\u89e3\u4e00\u4e0b\u5b83\u600e\u9ebc\u7528\u3002<\/b><\/p>\n<p><b><\/b><\/p>\n<p><strong>\u51fa\u8655:<a title=\"http:\/\/yes.nctu.edu.tw\/SQL\/StoredProcedure\/StoredProcedure.htm\" href=\"http:\/\/yes.nctu.edu.tw\/SQL\/StoredProcedure\/StoredProcedure.htm\">http:\/\/yes.nctu.edu.tw\/SQL\/StoredProcedure\/StoredProcedure.htm<\/a><\/strong><\/p>\n<p><b>\u64b0\u5beb Stored Procedures<\/b><\/p>\n<p>\u5229\u7528 ADO \u4f86\u5b58\u53d6\u8cc7\u6599\u5eab\u662f\u4e00\u4ef6\u65e2\u8f15\u9b06\u53c8\u7c21\u55ae\u7684\u5de5\u4f5c, \u4e0d\u904e\u6709\u7684\u6642\u5019\u53c8\u81ed\u53c8\u9577\u7684 SQL \u6558\u8ff0\u5be6\u5728\u5f88\u7169\u4eba, \u9019\u7bc7\u6587\u7ae0\u5c07\u4ecb\u7d39\u5982\u4f55\u5229\u7528 Stored Procedure \u4f86\u7c21\u5316\u4f60\u7684 ASP \u7a0b\u5f0f <\/p>\n<p>\u672c\u8cea\u4e0a Stored procedures (\u6709\u6642\u53c8\u7a31 Sproc) \u5c31\u662f\u5132\u5b58\u5728\u8cc7\u6599\u5eab\u4e2d\u7684 Script \u6216 Batch, \u64b0\u5beb Sproc \u4e26\u4e0d\u662f\u592a\u96e3\u7684\u4e00\u4ef6\u4e8b, \u901a\u5e38\u4f60\u6703\u9019\u6a23\u67e5\u8a62\u8cc7\u6599\u5eab <\/p>\n<p>Select * From Table <\/p>\n<p>\u5982\u4f55\u5c07\u5b83\u8b8a\u6210 Sproc? \u4ee5\u4e0b\u662f\u7c21\u55ae\u7684\u4f8b\u5b50 <\/p>\n<p>Create Proc sp_SprocName1    <br \/>As     <br \/>&#160; Select * From Table     <br \/>Go <\/p>\n<p>\u73fe\u5728 Sproc \u5df2\u6210\u529f\u7684\u5efa\u7acb, \u4f60\u53ef\u4ee5\u8a66\u8457\u53bb\u57f7\u884c\u5b83 <\/p>\n<p>Exec sp_SprocName1 <\/p>\n<p>\u4f60\u53ef\u4ee5\u70ba\u4f60\u7684 Sproc \u53d6\u4efb\u4f55\u7684\u540d\u5b57, \u5728 SQL 7.0 \u7684\u547d\u540d\u539f\u5247\u4ee5 128 \u500b\u5b57\u5143\u70ba\u9650, SQL \u4e26\u4e0d\u898f\u5b9a Stores procedure \u4e4b\u547d\u540d\u8981\u4ee5 sp_ \u958b\u982d, \u4f46\u5f37\u70c8\u5efa\u8b70\u4f60\u9019\u9ebc\u505a! <\/p>\n<p>\u63a5\u4e0b\u4f86\u6211\u5011\u518d\u505a\u4e9b\u4f8b\u5b50, \u4f8b\u5982\u5728\u67e5\u8a62\u4e2d\u52a0\u5165 where \u5b50\u53e5, Select * From Table Where Column1 = 0 , \u9019\u88e1\u4f60\u662f\u4e0d\u662f\u6703\u89ba\u5f97 Column1 \u7684\u503c\u5982\u679c\u53ef\u4ee5\u6539\u70ba\u4e00\u500b\u8f38\u5165\u53c3\u6578\u7531\u6211\u5011\u8f38\u5165, \u90a3\u5c31\u66f4\u52a0\u5b8c\u7f8e! <\/p>\n<p>Create Proc sp_SprocName2    <br \/>@MyInput int     <br \/>As     <br \/>&#160; Select * From Table     <br \/>&#160; Where Column1 = @MyInput     <br \/>Go <\/p>\n<p>\u5b8c\u6574\u7684\u53c3\u6578\u5ba3\u544a\u8a9e\u6cd5\u70ba <\/p>\n<p>@<i>parameter_name datatype<\/i> [= default|Null] [Varying] [Output] <\/p>\n<p>\u5982\u679c\u4f60\u672a\u63d0\u4f9b default \u503c, \u5247\u9019\u500b\u53c3\u6578\u6703\u88ab\u5047\u8a2d\u70ba\u5fc5\u8981\u8f38\u5165\u7684, \u5728\u5ba3\u544a\u53c3\u6578\u6642\u4f60\u9084\u5fc5\u9808\u6307\u5b9a\u8cc7\u6599\u578b\u614b, \u61c9\u70ba\u5408\u6cd5\u7684 SQL Server \u8cc7\u6599\u578b\u614b <\/p>\n<p>\u5728 Sproc \u63a5\u6536\u5230\u8f38\u5165\u503c\u5f8c, \u4fbf\u5c07\u5b83\u5b58\u653e\u5728 @MyInput \u8b8a\u6578\u4e2d, \u8b8a\u6578\u4ee5 @ \u7b26\u865f\u958b\u982d, \u4ee5 @@ \u958b\u982d\u7684\u5247\u70ba\u5168\u57df\u8b8a\u6578, \u4f60\u53ef\u4ee5\u9019\u9ebc\u57f7\u884c\u9019\u500b Sproc <\/p>\n<p>Exec sp_SprocName2 0 <\/p>\n<p>\u6211\u5011\u518d\u4f86\u770b\u4e00\u500b Insert \u7684\u4f8b\u5b50 <\/p>\n<p>Create Proc sp_SprocName3    <br \/>&#160; @Column1 varchar(20)     <br \/>&#160; @Column2 varchar(36) = Null     <br \/>As     <br \/>&#160; Insert Into Table     <br \/>&#160; Values     <br \/>&#160;&#160;&#160; (@Column1, @Column2)     <br \/>Go <\/p>\n<p>\u5728\u9019\u4f8b\u5b50\u4e2d, Column2 \u7684\u503c\u5373\u70ba\u9078\u64c7\u6027\u8f38\u5165, \u4f60\u53ef\u4ee5\u9019\u9ebc\u57f7\u884c <\/p>\n<p>Exec sp_SprocName3 &#8216;SomeString&#8217; <\/p>\n<p>\u6700\u5f8c\u8981\u544a\u8a34\u4f60\u5982\u4f55\u5728 ASP \u4e2d\u4f7f\u7528 Stored procedure, \u4e0d\u4f7f\u7528 Sproc \u6642\u4f60\u6703\u9019\u9ebc\u505a <\/p>\n<p>Set oConn = Server.CreateObject(&quot;Adodb.Connection&quot;)    <br \/>oConn.Open YpurDSN     <br \/>sSQL = &quot;Select * From Table&quot;     <br \/>Set oRs = oConn.Execute(sSQL) <\/p>\n<p>\u4f7f\u7528 Sproc \u6642, \u9019\u6a23\u6539\u5c31\u53ef\u4ee5\u4e86 <\/p>\n<p>Set oConn = Server.CreateObject(&quot;Adodb.Connection&quot;)    <br \/>oConn.Open YourDSN     <br \/>sSQL = &quot;sp_MySproc&quot;     <br \/>Set oRs = oConn.Execute(sSQL) <\/p>\n<p>\u5982\u679c\u4f60\u7684 Sproc \u9700\u8981\u8f38\u5165\u53c3\u6578, \u4f60\u53ef\u4ee5\u9019\u9ebc\u505a <\/p>\n<p>Set oConn = Server.CreateObject(&quot;Adodb.Connection&quot;)    <br \/>oConn.Open YourDSN     <br \/>sSQL = &quot;sp_MySproc &quot; &amp; MyInput     <br \/>Set oRs = oConn.Execute(sSQL) <\/p>\n<p>\u662f\u4e0d\u662f\u5f88\u7c21\u55ae\u5462! <\/p>\n<p>\u5e0c\u671b\u9019\u7bc7\u6587\u7ae0\u5c0d\u4f60\u6709\u5e6b\u52a9! <\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u4e00\u76f4\u90fd\u4e0d\u77e5\u5230\u5565\u662f\u9810\u5b58\u7a0b\u5e8f\uff0c\u5f8c\u4f86\u5927\u6982\u77e5\u9053\u5b83\u662f\u505a\u4ec0\u9ebc\u7528\u7684\uff0c\u76f4\u5230\u73fe\u5728\u624d\u958b\u59cb\u9762\u5c0d\u5b83\uff0c\u5927\u6982\u4e86\u89e3\u4e00\u4e0b\u5b83\u600e\u9ebc\u7528\u3002<\/p>\n<\/p>\n<p>\u51fa\u8655:http:\/\/yes.nctu.edu.tw\/SQL\/StoredProcedure\/StoredProcedure.htm<\/p>\n<p>\u64b0\u5beb Stored Procedures<\/p>\n<p>\u5229\u7528 ADO \u4f86\u5b58\u53d6\u8cc7\u6599\u5eab\u662f\u4e00\u4ef6\u65e2\u8f15\u9b06\u53c8\u7c21\u55ae\u7684\u5de5\u4f5c, \u4e0d\u904e\u6709\u7684\u6642\u5019\u53c8\u81ed\u53c8\u9577\u7684 SQL \u6558\u8ff0\u5be6\u5728\u5f88\u7169\u4eba, \u9019\u7bc7\u6587\u7ae0\u5c07\u4ecb\u7d39\u5982\u4f55\u5229\u7528 Stored Procedure \u4f86\u7c21\u5316\u4f60\u7684 ASP \u7a0b\u5f0f <\/p>\n<p>\u672c\u8cea\u4e0a Stored procedures (\u6709\u6642\u53c8\u7a31 Sproc) \u5c31\u662f\u5132\u5b58\u5728\u8cc7\u6599\u5eab\u4e2d\u7684 Script \u6216 Batch, \u64b0\u5beb Sproc \u4e26\u4e0d\u662f\u592a\u96e3\u7684\u4e00\u4ef6\u4e8b, \u901a\u5e38\u4f60\u6703\u9019\u6a23\u67e5\u8a62\u8cc7\u6599\u5eab <\/p>\n<p>Select * From Table <\/p>\n<p>\u5982\u4f55\u5c07\u5b83\u8b8a\u6210 Sproc? \u4ee5\u4e0b\u662f\u7c21\u55ae\u7684\u4f8b\u5b50 <\/p>\n<p>Create Proc sp_SprocName1    As     &#160; Select * From Table     Go [&#8230;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":[],"categories":[27],"tags":[264],"_links":{"self":[{"href":"http:\/\/blog.infinity.idv.tw\/index.php?rest_route=\/wp\/v2\/posts\/264"}],"collection":[{"href":"http:\/\/blog.infinity.idv.tw\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"http:\/\/blog.infinity.idv.tw\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"http:\/\/blog.infinity.idv.tw\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"http:\/\/blog.infinity.idv.tw\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=264"}],"version-history":[{"count":1,"href":"http:\/\/blog.infinity.idv.tw\/index.php?rest_route=\/wp\/v2\/posts\/264\/revisions"}],"predecessor-version":[{"id":504,"href":"http:\/\/blog.infinity.idv.tw\/index.php?rest_route=\/wp\/v2\/posts\/264\/revisions\/504"}],"wp:attachment":[{"href":"http:\/\/blog.infinity.idv.tw\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=264"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"http:\/\/blog.infinity.idv.tw\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=264"},{"taxonomy":"post_tag","embeddable":true,"href":"http:\/\/blog.infinity.idv.tw\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=264"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}