千家信息网

sybase中游标的使用示例

发表于:2025-11-08 作者:千家信息网编辑
千家信息网最后更新 2025年11月08日,以下是在sybase使用游标的示例,因为当初使用这个示例消耗了一定的时间,先特做以记录--查询直接授予用户的对象权限DECLARE cur_DBName CURSOR FOR SELECT [name
千家信息网最后更新 2025年11月08日sybase中游标的使用示例

以下是在sybase使用游标的示例,因为当初使用这个示例消耗了一定的时间,先特做以记录

--查询直接授予用户的对象权限

DECLARE cur_DBName CURSOR FOR SELECT [name] FROM master..sysdatabases
go

BEGIN
DECLARE @temDBName VARCHAR(30)
DECLARE @v_sql VARCHAR(8000)

CREATE TABLE #tb_t1(dbName VARCHAR(50) NULL ,objectName VARCHAR(50) NULL,userName VARCHAR(50) NULL ,loginName VARCHAR(50) NULL ,action INT NULL ,protecttype INT ,grantor INT)
OPEN cur_DBName
FETCH cur_DBName into @temDBName

WHILE @@SQLSTATUS=0
BEGIN
SET @v_sql='insert into #tb_t1 select '''+@temDBName+''',d.name,b.name,c.name,a.action,a.protecttype,a.grantor from '+@temDBName+'..sysprotects a
inner join '+@temDBName+'..sysusers b on a.uid = b.uid
inner join master..syslogins c on b.suid = c.suid
inner join '+@temDBName+'..sysobjects d on a.id = d.id
'

exec(@v_sql)
FETCH cur_DBName into @temDBName
END

close cur_DBName
deallocate CURSOR cur_DBName

SELECT * FROM #tb_t1
DROP TABLE #tb_t1
END

0