菜的像徐坤
排名
7
文章
192
粉丝
15
评论
16
ICP备案 :渝ICP备18016597号-1
网站信息:2018-2025TNBLOG.NET
技术交流:群号656732739
联系我们:contact@tnblog.net
公网安备:50010702506256
欢迎加群交流技术

sql游标

4899人阅读 2021/5/25 15:51 总访问:961088 评论:0 收藏:0 手机
分类: SQL

前言

什么是游标

游标类似于一个指针,游标就是把数据结果放到内存中,然后游标指向这个内存地址
作用: 
可以让我们一行一行的去处理数据

可以把游标理解成数据库中的SqlDataReader

使用游标的步骤:

1:创建游标  declare 游标名字 cursor for sql语句

2:打开游标  open 游标名字

3:查询游标(可以是遍历)    fetch next from 游标名称 into 接收的变量(可以是多个,赋值与顺序有关)

4:关闭游标  close 游标名字

5:删除游标  deallocate 游标名字

游标分为动态游标和静态游标

动态游标:主表数据变了, 游标数据会跟着变

静态游标:主表数据变了, 游标数据不会跟着变

创建一个游标

  1. --数据部分
  2. create table gongzi 
  3. (
  4. id int primary key identity (1001,1),
  5. sname varchar (20),
  6. money int
  7. )
  8. insert gongzi values('张三',3000)
  9. insert gongzi values('李四',3000)
  10. insert gongzi values('王五',3000)
  11. insert gongzi values('赵六',3000)
  12. insert gongzi values('张伟',3000)
  13. --创建游标
  14. declare mycursor cursor
  15. for select * from gongzi
  16. --打开游标
  17. open mycursor
  18. --一行一行的读取
  19. --fetch next from mycursor
  20. --循环读取完数据表中的数据
  21. declare @num int = 0
  22. while(@num<5)
  23. begin
  24. select @num = @num+1
  25. fetch next from mycursor
  26. end
  27. --关闭游标
  28. close mycursor
  29. --删除游标
  30. deallocate mycursor

游标查询结果


into 与数据库类型转换

sql类型转换
CAST(sql变量 as 转换过后的类型)

  1. --创建游标
  2. declare mycursor cursor
  3. for select money,sname from gongzi
  4. --打开游标
  5. open mycursor
  6. declare @name varchar(20),@money int
  7. declare @num int = 0
  8. while(@num<5)
  9. begin
  10. select @num = @num+1
  11. fetch next from mycursor into @money,@name
  12. print(@name+cast(@money AS varchar(20)))
  13. end
  14. --关闭游标
  15. close mycursor
  16. --删除游标
  17. deallocate mycursor

运行结果

评价

如何修改重置MD5加密后的sql用户密码

二次开发时,要加一个忘记密码的功能,后台写了修改密码的方法,数据库执行也修改成功,但是登录一直提示密码错误。之所以...

sql Server的几种分页方式和效率

--topnotin方式 selecttop条数*fromtablename whereIdnotin(selecttop条数*页数Idfromtablename) --ROW_NUMBER()O...

Mysql主从复制+读写分离

使用Mysql读写分离和主从复制的原因:*单台MySQL服务器的安全性,高可用性,高并发都是不满足实际的生产需要。介绍:1.MySQ...

sql Server 中使用游标

--声明一个游标 DECLAREMyCursorCURSOR FORSELECTTOP5FBookName,FBookCodingFROMTBookInfo//定义一个叫MyCursor的游标,...

Mysql控制台插入中文数据报错1366解决

计算机配置: windows系统.数据库:MySQL5.5.如图 : 下图为表结构信息:通过 show full columns from userinfo;查询所得 na...

sqlserver order by

order by 字段名order by 第几个字段(整形)order by 排序:order by 字段名:通过字段名指定的字段排序 order by 字段数...

sqlserver保障远程连接的安全性

如果是只读的话建个视图,建个普通用户只对该视图进行读。读写的话就只能自己在加一层代理服务,由代理来进行读写,各客户...

sqlerver添加用户与授权

添加用户安全性--&gt;登录名,然后右键新建登录名就可以了然后填写好相关信息就可以了右键属性,用户映射可以选择该用户可...

Mysql 游标创建

游标:可以来存储一个结果集,可以通过遍历来访问到每一个数据需求:分表数据。 把一张表的数据根据需求分离,创建不同的表...

没有为 sql 缓存通知启用数据库

C:\WINDOWS\Microsoft.NET\Framework\v2.0.50727\aspnet_regsql -S 数据库IP -U 登录名 -P 密码 -d 数据库名称 -t 表名 -et

sqlserver约束

添加表后操作约束--删除约束 altertableaj_testdropconstraintCK__aj_test__userAge__5EBF139D --为表aj_test添加默认...

c sql简单参数化写法

防止sql 注入的,简单参数化写法publicboolLogin(string_username,string_password) { using(SqlConnectionconn=newSqlCo...

mysql 存储过程报错:delimiter

最近刚学sql,学到了存储过程,每当练习的时候就一直出现问题。 现在记录CREATEPROCEDUREproc_out(OUTstuidINT) begin se...

Mysql 视图的(增删改 查)

要显示视图的定义,需要在SHOWCREATEVIEW子句之后指定视图的名称, 我们先来创建几张表,完事后在进行演示:--用户信息表...

sqlServer存储过程拼接sql语句,分页

在写有些存储过程的时候需要进行sql的拼接,然后在使用exec函数执行sql语句注意字符串的拼接,看下面一段存储过程的sql语句...