将Sql Server对象的当前拥有者更改成目标拥有者
发布时间:2024-01-13 04:41:00
数据库操作当中,当数据库对象列表不只有一个普通的元素——objectname时,你将要使用objectowner.objectname来引用对象,但如果需要更改当前数据库中对象的所有者可以使用系统存储过程 sp_changeobjectowner (点击这里更详细)
sp_changeobjectowner
更改当前数据库中对象的所有者。
语法: sp_changeobjectowner [ @objname = ] 'object' , [, @newowner = ] 'owner'. 参数. [@objname =] 'object'.
但往往由于数据库对象过多,希望批处理更改当前数据库中对象的所有者,那么你可以尝试使用Net Fetch的 nf_ChangeObjectOwner 存储过程来完成批处理。具体用法如下:
首先使用以下代码创建存储过程——
nf_ChangeObjectOwner
将Sql Server对象的当前拥有者更改成目标拥有者
语法:nf_ChangeObjectOwner [, @current_Owner = ] 'owner',[,@target_Owner =] 'owner',[ ,@modify_Type=] type
if exists (select * from sysobjects where id = object_id(N'[nf_ChangeObjectOwner]') and OBJECTPROPERTY(id, N'IsProcedure') = 1)
drop procedure nf_ChangeObjectOwner
GO
Create PROCEDURE nf_ChangeObjectOwner
@current_Owner nvarchar(255),
@target_Owner nvarchar(255),
@modify_Type int
/***********************************************************************************************
nf_ChangeObjectOwner
实现功能: 将Sql Server对象的当前拥有者更改成目标拥有者
**** 使用本代码前请备份数据库!
**** 所带来的安全问题,与俺家的驴子无关!
**** 欢迎斧头劈我,劈死偶有奖!
调用方法: Exec nf_ChangeObjectOwner @current_Owner,@target_Owner,@modify_Type
输入参数: @current_Owner nvarchar(255) --对象的当前拥有者
@target_Owner nvarchar(255) --对象的目标拥有者
@modify_Type int --0为默认,更改表的拥有者;1为视图和存储过程
输出参数: RETURN值 = -1 --操作对象为0,操作对象不存在
= -2 --操作失败,可能对象被锁定
= 0(默认值) --操作成功,打印更改对象数目@object_Num
@object_Num --SQL 打印值,返回更改成功的对象数目
@Write by Net Fetch. @At 2005/09/12
@Email: cnNetFetch*Gmail.Com blog.ad0.cn
************************************************************************************************/
AS
DECLARE @str_Tbl_Name nvarchar(255),@object_Num int,@current_Owner_uid smallint
Set @object_Num = 0
DECLARE @return_status int
Set @return_status = -1
Set @current_Owner_uid = (Select uid From sysusers Where [Name] = @current_Owner)
If Not (Len(@current_Owner_uid)>0)
RETURN -1
If (@modify_Type = 1)
DECLARE ChangeObjectOwner_Cursor CURSOR FOR Select [Name] From sysobjects Where (type='U' or type='V' or type='P') and userstat=0 and [Name]<>'nf_ChangeObjectOwner' and status>-1 and uid = @current_Owner_uid
Else
DECLARE ChangeObjectOwner_Cursor CURSOR FOR Select [Name] From sysobjects Where (type='U' or type='V' or type='P') and userstat<>0 and [Name]<>'dtproperties' and uid = @current_Owner_uid
OPEN ChangeObjectOwner_Cursor
BEGIN TRANSACTION Change_ObjectOwner
FETCH NEXT FROM ChangeObjectOwner_Cursor INTO @str_Tbl_Name
WHILE (@@FETCH_STATUS = 0)
BEGIN
Set @str_Tbl_Name = @current_Owner + '.' + @str_Tbl_Name
Print @str_Tbl_Name
EXEC @return_status = sp_changeobjectowner @str_Tbl_Name, @target_Owner
IF (@return_status <> 0)
BEGIN
ROLLBACK TRANSACTION Change_ObjectOwner
RETURN -2
END
Set @object_Num = @object_Num + 1
FETCH NEXT FROM ChangeObjectOwner_Cursor INTO @str_Tbl_Name
END
Print @object_Num
COMMIT TRANSACTION Change_ObjectOwner
CLOSE ChangeObjectOwner_Cursor
DEALLOCATE ChangeObjectOwner_Cursor
Go
Usage(使用方法): Exec nf_ChangeObjectOwner 'dbo','你的用户名',0
——将所有用户表的拥有者更改成'你的用户名'
Usage(使用方法): Exec nf_ChangeObjectOwner 'dbo','你的用户名',1
——将除了用户表之外数据库对象(视图、存储过程)的拥有者更改成'你的用户名'


猜你喜欢
- pygame实现代码雨动画如视频所示 利用pygame库实现了一个代码呈雨状下落的视觉效果部分代码如下import sysimport ra
- Qt Designer的介绍在PyQt中编写UI界面可以直接通过代码来实现,也可以通过Qt Designer来完成。Qt Designer的
- Eric A. Meyer 对基于 Web 标准的 CSS 与 HTML 绝非一知半解,他是这个领域杰出的专家,曾写过不少 CSS 方面的书
- 本文实例讲述了golang简单读写文件的方法。分享给大家供大家参考,具体如下:这里演示golang读写文件的方法:package maini
- 用pycharm写Scrapy框架的时候发现无法引用items.py里的类且自己写的工具类也无法被应用难受了我快一天了,下面我捋一捋我的解决
- 昨天还和裕波沟通我没有准备ppt,想以另一种互动的方式来交流。后来想想,每个人都准备了,我不准备也不太好意思,呵呵。今天在webrebuil
- 今天来介绍pandas中一个很有用的函数groupby,其实和hive中的groupby的效果是一样的,区别在于两种语言的写法问题。grou
- 在Windows环境下,经常遇到系统Over的情况,如果你在新装了系统和SQL Server 2005后,需要把SQL Server2000
- 思路复原魔方困难问题的分解:1、用合适的数据结构表示出三阶魔方的六个面以及每一面的颜色2、每一次不同旋转操作的实现3、复原时如何判断当前魔方
- 前言相信大家可能曾遇到过这种情况,在开发中类似站内信的需求时,我们经常要使用字符串模板,比如尊敬的用户${name}。。。。里面的${nam
- 本文实例讲述了smarty模板引擎从配置文件中获取数据的方法。分享给大家供大家参考。具体如下:当某个变量值,不希望在程序中写死时,就可以把该
- 引言pymysqlpool (本地下载)是数据库工具包中新成员,目的是能提供一个实用的数据库连接池中间件,从而避免在应用中频繁地创建和释放数
- zip通常用于将两个列表合并在一起以同时进行迭代遍历注意:直接使用zip输出结果为<zip at 0x1d72cf30bc8>,
- 打开和关闭文件操作:os.Open()函数能够打开一个文件,返回一个*File和一个err。对得到的文件实例调用close()方法能够关闭文
- 本文实例讲述了Python实现快速排序的方法。分享给大家供大家参考,具体如下:说起快排的Python实现,首先谈一下,快速排序的思路:1、取
- 首先我是从淘宝进去,爬取了按销量排序的所有(100页)女装的列表信息按综合、销量分别爬取淘宝女装列表信息,然后导出前100商品的 link,
- 很多人喜欢把一个网站中相同的部分象是统一的页面logo,版权声明等做成一个过程,然后放到一个include文件中,这样所有的页面就都可以使用
- 目录selenium介绍selenium原理Selenium安装部署步骤1. 准备好python环境:2. 下载selenium并安装:3.
- 过滤html代码的函数,当然也可以使用正则表达式。<%Function FilterHTML(strToFilter)&nb
- Python 开发学习的意义:(1)学习相关安全工具原理.(2)掌握自定义工具及拓展开发解决实战中无工具或手工麻烦批量化等情况.(3)在二次