SqlServer2000孤立用户解决方案
2007-12-19 15:14 四毛的家 阅读(273) 评论(0) 编辑 收藏 举报因此我们应该先想办法把旧用户给干掉。先在要操作的数据库中建立如下存储过程,代码如下:
Create PROCEDURE ChangeAllObjOwner (
@oldowner sysname,
@newowner sysname
)
AS
DECLARE @objname sysname
SET NOCOUNT ON
--检查旧用户是否存在
IF USER_ID(@oldowner) IS NULL
BEGIN
RAISERROR ('The @oldowner passed does not exist in the database', 16, 1)
RETURN
END
--检查新用户是否存在
IF USER_ID(@newowner) IS NULL
BEGIN
RAISERROR ('The @newowner passed does not exist in the database', 16, 1)
RETURN
END
DECLARE owner_cursor CURSOR FOR
Select name FROM sysobjects Where uid = USER_ID(@oldowner)
OPEN owner_cursor
FETCH NEXT FROM owner_cursor INTO @objname
WHILE (@@fetch_status <> -1)
BEGIN
SET @objname = @oldowner + '.' + @objname
EXEC sp_changeobjectowner @objname, @newowner
FETCH NEXT FROM owner_cursor INTO @objname
END
CLOSE owner_cursor
DEALLOCATE owner_cursor
GO
然后转到查询分析器,执行以上存储过程:
exec ChangeAllObjOwner 'olduser','dbo'
建议把对象都转成是dbo的,也就是sa帐号下的,这时候就可以删除旧用户了。然后再建一个新的登录用户,对应回数据库,然后可以再执行一次上述的存储过程,把数据sa的对象转给新用户。
在转移对象时会有一定的风险,但这种风险还是可以接受的,至少我到目前为止也没遇到对象被损坏的情况,大家不妨试试。
<本文系转载自:http://gdnpc.w247.dns911.cn/article.asp?id=21>
【推荐】还在用 ECharts 开发大屏?试试这款永久免费的开源 BI 工具!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步