设为首页 收藏本站
查看: 757|回复: 0

[经验分享] sql server 存储过程简介与使用方法

[复制链接]

尚未签到

发表于 2016-11-5 03:59:52 | 显示全部楼层 |阅读模式
语法:

DECLARE

{

{@local_variable data_type}

} [,...n]

例如:

declare @ID int --申明一个名为@ID的变量,类型为int型

三.在SQL Server窗口中打印出变量的值

语法:

PRINT 'any ASCII text' | @local_variable | @@FUNCTION | string_expr

四.变量赋值

例如:

--从数据表中取出第一行数据的ID,赋值给变量@id,然后打印出来

Declare @ID int

Set @ID = (select top(1) categoryID from categories)

Print @ID

在SQL中,我们不能像代码那样直接给变量赋值,例如@id = 1,如果要达到这样的功能,可以这样写:

Declare @ID int

Set @ID = (select 1) -- 类似 @ID=1

Select @id=1 -- 类似 @ID=1

Print @ID

五.变量运算(+,-,*,/,……)

以下必要时候省略变量申明

Set @ID = (select 1+5) --类似 @ID=1+5

Set @ID=(select 1-@ID) --类似 @ID=1-@ID

六.比较操作符

? > (greater than).

? < (less than).

? = (equals).

? <= (less than or equal to).

? >= (greater than or equal to).

? != (not equal to).

? <> (not equal to).

? ! < (not less than).

? !> (not greater than).

没什么说的

七.语句块:Begin … end

将多条语句作为一个块,类似与C++,C#中的{ }

例如:

Begin

Set @ID1 = (select 1)

Set @ID2 = (select 2)

End

八.If, if…else…

语法:

IF Boolean_expression

{sql_statement | statement_block}

[ELSE

{sql_statement | statement_block}]

例如:

If @id is not null

Print ‘@id is not null

if @ID = 1

begin

Set @ID = (select 1 + 1)

end

else

begin

set @ID=(select 1+2)

end

上面的例子用到了比较操作符,语句块,和IF的语法。

九.执行其他存储过程 EXEC

例如

EXEC dbo.[Sales by Year] @Beginning_Date=’1/01/90’, @Ending_Date=’1/01/08’

十.事务

语法:

BEGIN TRAN[SACTION] [transaction_name | @tran_name_variable]

例如

BEGIN TRAN

-- 做某些操作,例如Insert into …

if @@error <> 0

BEGIN

ROLLBACK TRAN

END

else

BEGIN

COMMIT TRAN

END

十一.游标

我们可以在存储过程中用Select语句取出每一行数据进行操作,这就需要用到游标。

语法:

DECLARE cursor_name CURSOR

[LOCAL | GLOBAL]

[FORWARD_ONLY | SCROLL]

[STATIC | KEYSET | DYNAMIC | FAST_FORWARD]

[READ_ONLY | SCROLL_LOCKS | OPTIMISTIC]

[TYPE_WARNING]

FOR select_statement

[FOR UPDATE [OF column_name [,...n]]]

例如:

DECLARE @au_id varchar(11), @au_fname varchar(20) –申明变量

--申明一个游标

DECLARE authors_cursor CURSOR FOR

SELECT au_id, au_fname FROM authors

--打开游标

OPEN authors_cursor

--取出值

FETCH NEXT FROM authors_cursor INTO @au_id, @au_fname

--循环取出游标的值

WHILE @@FETCH_STATUS = 0

BEGIN

Print @au_id

Print @au_fname

Print ‘ ’

FETCH NEXT FROM authors_cursor

INTO @au_id, @au_fname

END

CLOSE authors_cursor –关闭游标

DEALLOCATE authors_cursor --释放游标

我觉得上面的是存储过程常用的一些东东,如果要更深入的了解,更详细的帮助,请参考SQL Server的帮助文档



例子:

我自己做了一个,没有问题,你可以看一下   
  use   Northwind   
  go   
  create   proc   test   
      @StartOrderID   int,   
      @EndOrderID   int,   
      @Code   varchar(1000)   Out   
  As   
      Begin   
          Declare   @tmp   int   
                  Set   @Code=''           
                  Declare   #cur_orders   cursor     for     Select   OrderID   From   Orders     
                          where   OrderID>=@startOrderID   and   OrderID<=@EndOrderID   
                          for   read   only   
                  Open   #cur_Orders   
                  fetch   next   from   #cur_orders   into   @tmp   
                    while   @@fetch_Status=0   
                      Begin   
                              Set   @Code=@Code+'-'+convert(varchar(8),@tmp)   
                                fetch   next   from   #cur_orders   into   @tmp   
                      End   
                  close   #cur_Orders   
                  Deallocate   #cur_Orders   
                  return   
            
      End   
  go   


续2   
        String   ret=null;   
          try{   
              Class.forName("com.microsoft.jdbc.sqlserver.SQLServerDriver");   
              String   url   
  ="jdbc:microsoft:sqlserver://192.168.0.102:1433;DatabaseName=Northwind";   
              String   user="sa";   
              String   password="";   
              Connection   conn=   DriverManager.getConnection(url,user,password);   
              CallableStatement   stmt=conn.prepareCall("exec   test   ?,?,?");   
              stmt.setInt(1,10248);   
              stmt.setInt(2,10284);   
              stmt.registerOutParameter(3,Types.VARCHAR);   
              stmt.setString(3,ret);   
              stmt.execute();   
              System.out.println(stmt.getString(3));   
              stmt.close();   
              stmt=null;   
              conn.close();   
          }catch(ClassNotFoundException   e){   
              e.printStackTrace();   
          }catch(SQLException   e){   
              e.printStackTrace();   
          }   


上面的例子没有问题,针对你的情况,我又写了一个,应该可以解决你现在的问题   
   
  --   新建一个表   
      Create   table   tmpOrders   (   
            OrderID   int,   
            CustomerID   nchar(5)   
    )   
   
  --把Orders   里的OrderID列全部插入,这样Orders与tmpOrders之间就是1:1关系了   
  insert   into   tmpOrders   
  Select   distinct   orderID,'tmp'   from   Orders   
   
  create   proc   test   
      @StartOrderID   int,   
      @EndOrderID   int,   
      @Code   varchar(1000)   Out   
  As   
      Begin   
          Declare   @newOrderID   int   
          Declare   @newCustomerID   nchar(5)   
          Declare   @DummyInt   int   
          Declare   @DummyChar   nchar(5)   
                  Set   @Code=''      
                  /*   
                                                                                                                                  1:1     
                          temp   table/formal   table   is   synchronized   tmpOrders     <--->   Orders   
                          fetch   from   Orders,   update   tmpOrders   
                  */   
   
                  --   for   temp   table   
                  Declare   #cur_tmpOrders     Cursor   for   select   OrderID,CustomerID     
                                From   tmpOrders     
                                      where   OrderID>=@startOrderID     
                                      and   OrderID<=@EndOrderID                                    
                                      for     update   
   
                  --for   formal   table   
                  Declare   #cur_orders   cursor     for     Select   OrderID,CustomerID     
                            From   Orders     
                          where   OrderID>=@startOrderID     
                          and   OrderID<=@EndOrderID     
                          for   read   only   
                  Open   #cur_Orders   
                  Open   #cur_tmpOrders   
   
                  fetch   next   from   #cur_tmpOrders   into   @DummyInt,@dummyChar   --Important!!!   
                  fetch   next   from   #cur_orders   into   @NewOrderID,@NewCustomerID   
                    while   @@fetch_Status=0   
                      Begin   
                              --Set   @Code=@Code+'-'+convert(varchar(8),@NewOrderID)   
                              --update   tempOrders   use   corresponding   Orders'   data   
                                Update   tmpOrders   set   customerID=@newCustomerID     
                                          where   current   of   #cur_tmpOrders     
                                --pay   attention   to   sequence   of   cursor   fetch   action!   
                                fetch   next   from   #cur_tmpOrders   into   @DummyInt,@dummyChar   
                                if   @@fetch_Status<>0     break;   --   没有行了   
                                fetch   next   from   #cur_orders   into   @newOrderID,@NewCustomerID   
                      End   
   
                  close   #cur_Orders   
                  close   #cur_tmpOrders   
   
                  Deallocate   #cur_Orders   
                  Deallocate   #cur_tmpOrders   
                  Set   @Code='Ok'   
                  return   
            
      End   



程序如下   
          try{   
              Class.forName("com.microsoft.jdbc.sqlserver.SQLServerDriver");   
              String   url=   
  "jdbc:microsoft:sqlserver://192.168.0.102:1433;DatabaseName=Northwind";   
              String   user="sa";   
              String   password="";   
              Connection   conn=   DriverManager.getConnection(url,user,password);   
              CallableStatement   stmt=conn.prepareCall("exec   test     ?,?,?");   
              stmt.setInt(1,10248);   
              stmt.setInt(2,10284);   
              stmt.registerOutParameter(3,Types.VARCHAR,1000);   
              stmt.setString(3,ret);   
              stmt.executeUpdate();   
              System.out.println(stmt.getString(3));   
              stmt.close();   
              stmt=null;   
              conn.close();   
              conn=null;   
          }catch(ClassNotFoundException   e){   
              e.printStackTrace();   
          }catch(SQLException   e){   
              e.printStackTrace();   
          }

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-295789-1-1.html 上篇帖子: 一个struts+sql server得分页(存储过程版) 下篇帖子: SQL Server 2000数据库存储过程的调用(VB)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表