一、游标的使用场景
我们平常对数据库中的数据进行增删改时,都是一次性处理若干行符合指定条件的数据,而如果有个业务场景,要求我们对某些数据逐行进行判断并采取不同的方式处理,这时候一般的语句就满足不了了.
游标可以方便从一个结果集中进行循环遍历数据在进行操作。它的思想就是从结果集中,一个一个取出来处理.当然,由于它是逐一处理的方式,游标的最大弊端就是低效.
二、游标的类型与格式
游标分为两种,静态游标和动态游标,默认的都是动态游标
静态游标在打开时会将数据集存储在tempdb中,因此显示的数据与游标打开时的数据集保持一致,在游标打开以后对数据库的更新不会显示在游标中。
动态游标在打开后会反映对数据库的更改。所有UPDATE、INSERT 和 DELETE 操作都会显示在游标的结果集中,结果集中的行数据值、顺序和成员在每次提取时都会改变。
关于静态游标和动态游标的区别,可以看博主"二月十六"的《SQL SERVER 游标使用》。
--创建一个游标
declare my_cursor cursor STATIC --my_cursor为游标的名称,随便起,STATIC加上就是静态游标,去掉就是动态游标
for
select name,id from table --这是游标my_cursor的值,这里随便发挥看业务场景
--打开游标
open my_cursor --打开游标
--变量
declare @name varchar(150) --声明变量 ‘declare’为声明变量 ‘@name’为变量名称 后面为变量类型
declare &