SQL 循环语句几种写法

这篇具有很好参考价值的文章主要介绍了SQL 循环语句几种写法。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

1、if语句使用示例

1

2

3

4

5

6

7

8

9

10

declare @a int

set @a=12

if @a>100

begin

  print @a

end

else

begin

  print 'no'

end

2、while语句使用示例

1

2

3

4

5

6

7

8

declare @i int

set @i=1

while @i<30

begin

  insert into test (userid) values(@i)

set @i=@i+1

end

-- 设置重复执行 SQL 语句或语句块的条件。只要指定的条件为真,就重复执行语句。可以使用 BREAK 和 CONTINUE 关键字在循环内部控制 WHILE 循环中语句的执行。 

3、临时表和try

1

2

3

4

5

6

7

8

-- 增加临时表

select into #csj_temp from csj

-- 删除临时表 用到try

begin try -- 检测代码开始

  drop table #csj_temp

end try

begin catch -- 错误开始

end catch

  

4、正常循环语句

1

2

3

4

5

6

7

8

9

10

11

12

13

14

declare @orderNum varchar(255)

create table #ttableName(id int identity(1,1),Orders varchar(255))

declare @n int,@rows int

insert #ttableName(orders) select orderNum from pe_Orders where orderId<50

--select @rows=count(1) from pe_Orders

select @rows =@@rowcount

set @n=1

while @n<=@rows

begin

  select @orderNum=OrderNum from PE_Orders where OrderNum=(select Orders from #ttableName where id=@n)

  print (@OrderNum)

  select @n=@n+1

end

drop table #ttableName

5、不带事务的游标循环

1

2

3

4

5

6

7

8

9

10

11

12

13

declare @orderN varchar(50)  --临时变量,用来保存游标值

declare y_curr cursor for   --申明游标 为orderNum

select orderNum from pe_Orders where orderId<50

open y_curr   --打开游标

fetch next from Y_curr into @orderN   ----开始循环游标变量

while(@@fetch_status=0)  ---返回被 FETCH 语句执行的最后游标的状态,而不是任何当前被连接打开的游标的状态。

begin

  print (@orderN)

  update pe_Orders set Functionary+@orderN where orderNum=@orderN   --操作数据库

  fetch next from y_curr into @orderN   --开始循环游标变量

end

close y_curr  --关闭游标

deallocate y_curr   --释放游标

6、带事务的游标循环

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

select orderNum,userName,MoneyTotal into #t from pe_Orders po

DECLARE @n int,@error int

--set @n=1

set @error=0

BEGIN TRAN   --申明 开始事务

declare @orderN varchar(50),@userN varchar(50)   --临时变量,用来保存游标值

declare y_curr cursor for    --申明游标 为orderNum,userName

select orderNum,userName from PE_Orders where Orderid<50

open y_curr

fetch next from y_curr into @orderN,@userN

while @@fetch_status = 0

BEGIN

  select isnull(sum(MoneyTotal),0),orderNum from #t where username=@userN

  -- set @n=@n+1

  set @error=@error+@@error  --记录每次运行sql后 是否正确 0正确

  fetch next from y_curr into @orderN,@userN

END

IF @error=0

BEGIN

  commit tran   ---事务提交

END

ELSE

BEGIN

  ROLLBACK TRAN   ---事务回滚

END

close y_curr

deallocate y_curr

DROP TABLE #t

   

7、游标循环读记录

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

declare @temp_temp int

--declare @Cur_Name

--@Cur_Name="aaa"

--------------------------------- 创建游标 --Local(本地游标)

DECLARE aaa CURSOR for select House_Id from House_House where Deleted=0 or deleted is null

----------------------------------- 打开游标

Open aaa

----------------------------------- 遍历和获取游标

fetch next from aaa into @temp_temp

--print @temp_temp

while @@fetch_status=0

begin

  --做你要做的事

  select from House_monthEnd where House_Id=@temp_temp

  fetch next from aaa into @temp_temp -- 取值赋给变量

--

end

----------------------------------- 关闭游标

Close aaa

----------------------------------- 删除游标

Deallocate aaa文章来源地址https://www.toymoban.com/news/detail-539134.html

到了这里,关于SQL 循环语句几种写法的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 数据库作业-sql语句查询

    建表的插入数据的表 数据库作业-sql建表和插入数据_快乐的xiao何的博客-CSDN博客 create table supplier( supplierno char(6) primary key, suppliername nvarchar(10), address nvarchar(20), number char(11) )create table category( categoryno char(5) primary key, categoryname varchar(20), descriptions text... https://blog.csdn.net/m0_539670

    2023年04月23日
    浏览(57)
  • SQL语句创建数据库详解

    在SQL中,创建数据库的语句通常是使用 CREATE DATABASE 语句。让我们来详细解释一下这个语句,并通过一个示例来说明如何创建数据库。 CREATE DATABASE语句详解 CREATE DATABASE 语句用于在数据库管理系统中创建一个新的数据库。它的基本语法如下: 其中, database_name 是要创建的数据

    2024年02月19日
    浏览(60)
  • 数据库sql语句(视图的创建)

    例题:  建表:要注意各表之间的索引联系,建表先后顺序很重要,不然建不了,例如先建dept,在建其他表,先在dept插入数据,再在其他表插入数据 (1) (2)  (3)  (4) (5)    插入数据如下图 sql语句: 在 Student 表中加入属性 SAGE(INT 型 )  将 Student 表中的属性 SA

    2024年02月04日
    浏览(70)
  • SQL 选择数据库 USE语句

    当SQL Schema中有多个数据库时,在开始操作之前,需要选择一个执行所有操作的数据库。 SQL USE语句用于选择SQL架构中的任何现有数据库。 句法 USE语句的基本语法如下所示 : 数据库名称在RDBMS中必须是唯一的。 您可以查看可用的数据库,如下所示: 现在,如果您想使用AMROOD数

    2024年02月08日
    浏览(59)
  • 数据库学习-常用的SQL语句

    背景: 汇整一下自己学习数据库过程中常见的题目及语句。 一.实例分析题     二.简单SQL查询: 三.复杂SQL查询 有3个表(15分钟):(SQL) Student 学生表 (学号,姓名,性别,年龄,组织部门) Course 课程表 (编号,课程名称) Sc 选课表 (学号,课程编号,成绩) 表结构如下:

    2023年04月21日
    浏览(51)
  • SQL 数据库语句- 创建和管理数据库

    SQL CREATE DATABASE 语句用于创建一个新的 SQL 数据库。 以下 SQL 语句创建了一个名为 \\\"testDB\\\" 的数据库: 通过这个简单的语句,你可以成功地创建一个名为 \\\"testDB\\\" 的数据库。记得在实际应用中,你可能需要添加其他选项,比如指定字符集、校对规则等,以满足具体需求。 SQL DRO

    2024年02月05日
    浏览(81)
  • 在SQL server中用sql语句实现数据库的备份以及还原

    本文给大家提供并讲解了在SQL server中用SQL语句实现数据库的备份已经还原 假设你已经有一个数据库Student 创建备份设备,其名称为bk_Student,保存文件为D: Student.bak,并对Student数据库进行完全备份,备份到备份设备bk_ Student中。  在Student数据库中,创建一张表temp并对Student数

    2024年02月03日
    浏览(62)
  • 用SQL语句操作Oracle数据库——数据更新

    数据库中的数据更新操作有3种:1)向表中添加若干行数据(增);2)删除表中的若干行数据(删);3)修改表中的数据(改)。对于这3种操作,SQL语言中有3种相应的语句与之对应。接下来让我们逐一详细地了解一下。 本文我们依然使用以下三个表来进行数据更新操作:

    2024年01月19日
    浏览(67)
  • 数据库基础——数据库、数据表和SQL语句

    数据库是用来存储、管理数据的仓库 数据表是数据的存储结构 Structured Query Language,结构化查询语言,用来操作数据库 安装MySQL,自行百度 进入cmd使用命令 mysql -hAddress -uUser -p(Password) 登录数据库 -p后直接回车可进入密文登录 如果出现以下报错,则打开任务管理器-服务-开启

    2024年02月09日
    浏览(74)
  • 【数据库】MySQL 高级(进阶) SQL 语句

    location表格创建 store_info表格创建 显示表格中一个或数个字段的所有数据记录 不显示重复的数据记录 按照条件进行查询 在已知的字段数据取值范围内取值 另外还有not in命令,用法一致,表示显示不在指定范围内的字段的值。 在两个字段数据值之间取值,包含两边字段的数据

    2024年02月09日
    浏览(136)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包