zoukankan      html  css  js  c++  java
  • SqlServer和Oracle中一些常用的sql语句7 游标

    declare db_cursor5 scroll cursor for select amazonOrderid,Name,AddressLine1 from dbo.OrdersAddress   --声明游标  
    declare @t varchar(max)                                                   --定义变量  
    declare @t1 varchar(max)  
    declare @t2 varchar(max)  
    open db_cursor5                                                          --打开游标  
    Fetch Next From db_cursor5 Into @t,@t1 ,@t2    --提取游标中的数据保存到变量中 
        while(@@fetch_status= 0)
            begin   
                Fetch Next From db_cursor5 Into @t,@t1 ,@t2 
                /*这里放置循环操作逻辑*/
                print (@t+'--------'+@t1+'--------'+@t2)
            end 
    close db_cursor5                                     --关闭游标  
    deallocate db_cursor5                                --释放游标  
    
    /*
    105-3393966-8059426--------casey brown--------9453 PICKFORD PL
    115-3011976-1227434--------Therese Hecker--------2210 Glenwood Rd
    105-3393966-8059426--------casey brown--------9453 PICKFORD PL
    105-3393966-8059426--------casey brown--------9453 PICKFORD PL
    */
    ALTER PROC [dbo].[SynchData_SP]
           
    AS
    	declare db_cursor scroll cursor for select [userid],[username],[status] from demotemp  --声明游标    
    	declare @t1 int      --定义变量    
    	declare @t2 varchar(max)    
    	declare @t3 varchar(max)    
    	open db_cursor     --打开游标    
    	Fetch Next From db_cursor Into @t1,@t2 ,@t3    --提取游标中的数据保存到变量中   
    		while(@@fetch_status= 0)  
    			begin     
    				/*目标表存在则修改,不存在则新增*/  
    				IF NOT EXISTS (SELECT userid FROM demo  WHERE userid=@t1)
    					BEGIN
    						INSERT INTO demo(userid,username,STATUS) VALUES(@t1,@t2,@t3 ) 
    					END
    				ELSE
    					BEGIN
    						UPDATE demo SET  STATUS=@t3 WHERE userid=@t1
    					END				
    				Fetch Next From db_cursor Into @t1,@t2 ,@t3   				
    			end   
    	close db_cursor		--关闭游标    
    	deallocate db_cursor   --释放游标   
       
    declare db_cursor4  scroll cursor for select * from  供应商  --声明游标
    open db_cursor4                                              --打开游标
    fetch first from db_cursor4                 --读取游标中的第一条数据记录
    fetch next from db_cursor4                  --读取游标中的下一条数据记录
    fetch last from db_cursor4                  --读取游标中的最后一条数据记录
    fetch prior from db_cursor4                 --读取游标中的上一条数据记录
    fetch absolute 2 from db_cursor4            --读取游标中的第二条数据记录
    fetch relative 2 from db_cursor4            --读取游标当前记录下方的第二条数据记录
    close db_cursor4                            --关闭游标
    deallocate db_cursor4                       --释放游标
    
    --利用变量输出游标中的字段值                                            
    declare db_cursor5 scroll cursor for select 职工号,姓名,工资 from 职工   --声明游标
    declare @t varchar(10)                                                   --定义变量
    declare @t1 varchar(10)
    declare @t2 int
    open db_cursor5                                                          --打开游标
    fetch absolute 4 from db_cursor5 into @t,@t1,@t2     --提取游标中的数据保存到变量中
    select @t as 职工号,@t1 as 职工名,@t2 as 工资        --输出变量中的值
    close db_cursor5                                     --关闭游标
    deallocate db_cursor5                                --释放游标
    
    --利用游标判断记录是否存在
    declare db_cursor8 cursor scroll for  select * from 职工 where 职工号='zg2'
    open db_cursor8
    if @@fetch_status=0            --if条件语句
      print '存在该记录'
    else
      print '不存在该记录'
    close db_cursor8
    deallocate db_cursor8
    
    --在存储过程中使用游标
    create procedure db_mypro 
    @x int
    as
    begin
      declare mycursor scroll cursor
      for
      select * from 职工
      open mycursor
      fetch absolute @x from mycursor
      close mycursor
      deallocate mycursor
    end
    
    --显示职工表中的第五条记录
    execute db_mypro 5  
    

  • 相关阅读:
    Axiom3D:资源引用与加载基本流程.
    实践:C++平台迁移以及如何用C#做C++包装层
    Axiom3D:Buffer漫谈
    CSS: hover选择器的使用
    TTS 语音修复 ,缺少文件的,没注册类的
    sqlserver 查找某个字段在哪张表里
    Excel 表格查找重复数据,去重复统计
    C# HttpWebResponse WebClient 基础连接已经关闭: 发送时发生错误.
    C# 控件置于最顶层、最底层
    C# 线程 正确使用Thread.Join()停止方式
  • 原文地址:https://www.cnblogs.com/smartsmile/p/6234274.html
Copyright © 2011-2022 走看看