游标遍历所有数据库循环执行修改数据库的sql命令

简介: 原文:游标遍历所有数据库循环执行修改数据库的sql命令 MSSQL数据库服务器上有很多类似的数据库,需要将这些数据库统一修改其中的某些表或者某些命令,那么就会想到用游标来遍历。 先来说思路: 1,首先需要查询出所有的数据库;   select [name] from [master].
+关注继续查看
原文:游标遍历所有数据库循环执行修改数据库的sql命令

MSSQL数据库服务器上有很多类似的数据库,需要将这些数据库统一修改其中的某些表或者某些命令,那么就会想到用游标来遍历。

先来说思路:

1,首先需要查询出所有的数据库;

  select [name] from [master].[dbo].[sysdatabases] order by [name]; --查询MSSQL中所有数据库名称

2,用游标CURSOR来集合查询出来的数据库名称集合,来实现循环遍历每一个数据库;

3,在循环遍历每一个数据库名称时,通过拼接sql语句来实现命令字符串,并且用EXEC执行命令;

注意:可以根据个人需要对数据库名称进行筛选。

 

代码示例如下:

DECLARE @sysname sysname; --数据库名称变量

DECLARE My_Cursor CURSOR --定义游标
FOR (select [name] from [master].[dbo].[sysdatabases]) --查出所有的数据库名称的集合放到游标中
OPEN My_Cursor; --打开游标
FETCH NEXT FROM My_Cursor INTO @sysname; --读取下一行/第一行数据并存放在变量值中
WHILE @@FETCH_STATUS = 0 --是否可继续执行循环状态
    BEGIN
        --PRINT @sysname;
        DECLARE @sql nvarchar(max); --sql命令字符串
        SET @sql='USE ['+@sysname+'];';
        --Begin
        
        if (CHARINDEX('_QtxApp', @sysname)>0) --我只需要修改名字包含_QtxApp的数据库
        begin
            SET @sql+='select * from dbo.Access_token'; --自定义的sql命令
            PRINT @sql;
        end
        else
        begin
            PRINT @sql;
        end
        
        --End
        EXEC(@sql); --执行字符串sql
        
        FETCH NEXT FROM My_Cursor INTO @sysname; --读取下一行数据并存放在变量值中
    END
CLOSE My_Cursor; --关闭游标
DEALLOCATE My_Cursor; --释放游标
GO

 

结束,欢迎指正。

 

目录
相关文章
|
2月前
|
SQL 存储 数据库
SQL Server—游标(是什么?声明、打开、检索、关闭、释放)
是一种数据访问机制,它允许用户单独的操作数据行,而不是对整个行集进行操作。用户可以通过单独处理每一行逐条手机信息并对数据逐行进行操作,这样可以降低系统开销和潜在的阻隔情况。用户也可以使用这些数据生成SQL代码并立即执行或输出
|
3月前
|
SQL 缓存 监控
为什么Oracle中包含绑定变量的SQL会有多个游标?(译文)
为了改进包含绑定变量的SQL的执行计划,Oracle在11g版本中引入了一项名为自适应游标共享(ACS,Adaptive Cursor Sharing)的新功能。
|
4月前
|
SQL 存储 Oracle
PL/SQL编程—游标
PL/SQL编程—游标
40 0
|
8月前
|
存储 SQL 安全
SQL 存储过程和函数的对比、变量、条件和处理程序、游标、流程控制详解+代码示例
SQL 存储过程和函数的对比、变量、条件和处理程序、游标、流程控制详解+代码示例
|
8月前
|
存储 SQL 程序员
【Sql Server】 使用游标循环记录更新字段值
使用游标循环记录更新字段值
240 0
【Sql Server】 使用游标循环记录更新字段值
|
11月前
|
SQL API 数据库
数据库原理与应用(SQL Server)笔记 第十一章 游标
数据库原理与应用(SQL Server)笔记 第十一章 游标
数据库原理与应用(SQL Server)笔记 第十一章 游标
|
SQL 数据库 Windows
sql 2008 R2 函数、游标的创建和使用
sql 2008 R2 函数、游标的创建和使用
203 0
推荐文章
更多