SQL语句中的循环

SQL语句中的循环

SQL语句中的循环类似于foreach循环,可以循环遍历某个表并进行新增、修改和删除的操作。

SQL语句中的循环,使用SQL的游标来实现。

上示例:

declare @ID int;--声明变量(@名称 类型)
begin--开始
	print '示例'--输出
	declare a_test_main cursor for select ID from TableName1--查出需要循环的集合放到游标中
	open a_test_main;--打开游标
	while 1=1--开始循环
	begin--开始
		fetch next from a_test_main into @ID--赋值到变量中
		if(@@fetch_status!=0)break;--如果没有结果退出循环
		if not exists(select * from TableName2 where ID = @ID)--判断不存在数据
		begin--开始
			print '新增'--输出
			insert into TableName2 (ID)values(@ID)--不存在数据时执行(新增)
		end--结束
		if exists(select * from TableName3 where ID = @ID)--判断存在数据
		begin--开始
			print '修改'--输出
			update TableName3 set ID = 1 where ID = @ID--存在数据时执行(修改)
		end--结束
		if exists(select * from TableName4 where ID = @ID)--判断存在数据
		begin--开始
			print '删除'--输出
			delete from TableName4 where ID = @ID--存在数据时执行(删除)
		end--结束
	end--结束
	close a_test_main--关闭游标
	deallocate a_test_main--释放游标
end--结束

  • 9
    点赞
  • 54
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
SQL Server,没有像Oracle那样的for循环。但是可以使用游标(cursor)来实现循环操作。下面是一个使用游标实现循环SQL语句的示例: ```sql declare @id int, @name varchar(20), @class varchar(20) declare student_cursor cursor for select id, name, class from student open student_cursor fetch next from student_cursor into @id, @name, @class while @@FETCH_STATUS = 0 begin -- 在这里可以编写你的逻辑操作 -- 例如:将数据插入临时表 #temp insert into #temp select * from student where id = @id fetch next from student_cursor into @id, @name, @class end close student_cursor deallocate student_cursor ``` 在上述示例,我们首先声明了三个变量 @id、@name 和 @class,然后使用 cursor 选择需要循环的数据集。接下来,我们打开游标并将游标指向第一行数据。然后,使用 while 循环来分别处理每一行数据,直到所有数据都被处理完毕。在循环,可以根据需要编写具体的逻辑操作,例如将数据插入临时表 #temp。最后,关闭游标并释放相关资源。 需要注意的是,每次循环都需要使用 fetch next 语句将游标指向下一行数据,以及使用 @@FETCH_STATUS 来检查是否还有数据可供处理。如果 @@FETCH_STATUS 返回 0,则表示还有数据需要循环处理;返回 -1,则表示没有更多数据可供提取;返回 -2,则表示提取的行不存在。 因此,使用游标和循环的方式可以在 SQL Server 实现类似于 for 循环的功能。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [sql serverfor循环的应用总结](https://blog.csdn.net/ok060/article/details/130966687)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

新鑫S

你的鼓励将是我创作最大的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值