修改表和存储过程的所有者

批量修改表的所有者:  
  EXEC   sp_MSforeachtable   'exec   sp_changeobjectowner   ''?'',''dbo''   '  
  单个修改表所有者:  
  exec   sp_changeobjectowner   'dtproperties','dbo'


sp_changedbowner 'new_user'
更改当前数据库的所有者。


--批量修改数据库对象的所有者

新建一个存储过程:changename
if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[changename]') and OBJECTPROPERTY(id, N'IsProcedure') = 1)
drop procedure [dbo].[changename]
GO

SET QUOTED_IDENTIFIER OFF
GO
SET ANSI_NULLS OFF
GO

Create PROCEDURE dbo.changename
@OldOwner as NVARCHAR(128),--参数原所有者
@NewOwner as NVARCHAR(128)--参数新所有者
AS

DECLARE @Name as NVARCHAR(128)
DECLARE @Owner as NVARCHAR(128)
DECLARE @OwnerName as NVARCHAR(128)

DECLARE curObject CURSOR FOR
select 'Name' = name,
'Owner' = user_name(uid)
from sysobjects
where user_name(uid)=@OldOwner
order by name

OPEN curObject
FETCH NEXT FROM curObject INTO @Name, @Owner
WHILE(@@FETCH_STATUS=0)
BEGIN  
if @Owner=@OldOwner
begin
set @OwnerName = @OldOwner + '.' + rtrim(@Name)
exec sp_changeobjectowner @OwnerName, @NewOwner
end

FETCH NEXT FROM curObject INTO @Name, @Owner
END

close curObject
deallocate curObject
GO
SET QUOTED_IDENTIFIER OFF
GO
SET ANSI_NULLS ON
GO

以SA登陆查询分析器 ,选中你要的数据库
执行存储过程
执行exec Changename '原所有者','dbo'
或exec Changename 'dbo,'数据库所有者'


修改MS SQL表用户属性的命令 
 
可以用exec sp_changeobjectowner 'dataname.数据表','dbo' 把表或存储过程中的所有者都改成dbo

把所有视图,存储过程,表修改为dbo

declare tb cursor local for select 'sp_changeobjectowner ''['+replace(user_name(uid),']',']]')+'].[' +replace(name,']',']]')+']'',''dbo''' from sysobjects where xtype in('U','V','P','TR','FN','IF','TF') and status>=0 open tb declare @s nvarchar(4000) fetch tb into @s while @@fetch_status=0 begin exec(@s) fetch tb into @s end close tb deallocate tb

Go

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: SQL Server 存储过程是一组预编译的 T-SQL 语句,它们被存储数据库中,并可以通过名称调用执行。存储过程可以带参数,也可以返回结果集或输出参数。存储过程可以用于实现复杂的业务逻辑、数据访问控制等功能。 以下是一个简单的 SQL Server 存储过程示例: ``` CREATE PROCEDURE GetCustomers @City nvarchar(50) AS BEGIN SELECT * FROM Customers WHERE City = @City END ``` 以上存储过程接收一个城市名称作为参数,然后返回该城市的所有客户记录。 执行存储过程的语法如下: ``` EXEC GetCustomers 'Los Angeles' ``` 以上语句将调用名为 GetCustomers 的存储过程,并将 'Los Angeles' 作为参数传递给它。 ### 回答2: SQL Server存储过程是一组预编译的SQL语句和命令的集合,它们被打包成一个单元,然后在需要的时候被调用执行。存储过程通常用于处理和管理数据库中的复杂逻辑和业务规则。 存储过程的主要优势之一是提高了数据库的性能。当存储过程被创建后,它会被编译,并且在后续的调用过程中可以重复使用编译结果,从而减少了每次执行查询所需的时间。此外,存储过程还可以降低网络流量,因为只需要向数据库发送一条命令,而不是多次发送多个查询。 另一个优势是存储过程可以更好地保护数据库的安全性。通过存储过程,可以限制用户对数据库中的特定数据和操作的访问权限。这样可以防止用户直接修改、删除或插入数据库中的数据,同时还可以记录用户对数据库的操作,以便进行审计。 此外,存储过程还有以下特点: 1. 可以接受输入参数和返回输出参数,使得存储过程可以根据不同的输入进行不同的操作,并返回结果给调用者。 2. 可以包含流程控制语句,如条件判断和循环,使得存储过程可以实现更复杂的业务逻辑。 3. 可以在一个事务中执行多个SQL语句,从而保证了数据库的一致性和完整性。 4. 可以被其他存储过程或脚本调用,实现代码的复用和模块化。 总之,SQL Server存储过程是一种强大的数据库工具,可以提高性能、保护安全性,并且具有代码复用和模块化的优点。它在处理和管理数据库中的复杂逻辑和业务规则方面发挥着重要的作用。 ### 回答3: sqlserver存储过程是一组预先编译的、可重用的SQL代码,它被存储数据库中并可以通过名称调用执行。存储过程可以接受输入参数,并返回一个或多个结果集,以满足特定的业务需求。 使用存储过程有以下几个优点: 1. 提高性能:存储过程数据库中进行预编译,可以减少网络传输和编译时间。此外,存储过程还可以对数据库进行优化,以提高查询的执行速度。 2. 提高安全性:存储过程可以限制对数据库的直接访问,通过存储过程执行SQL语句,可以有效地防止恶意的数据操作和SQL注入攻击。 3. 降低维护成本:存储过程可以被多个应用程序共享和重用,这样可以减少代码重复的工作量。当需要对某个业务逻辑进行修改时,只需要修改存储过程的代码,而不必修改多个应用程序。 4. 支持事务处理:存储过程中可以包含事务管理的逻辑,可以确保数据的一致性和完整性。在存储过程中,可以使用BEGIN TRANSACTION、COMMIT和ROLLBACK语句来管理事务。 5. 提高可维护性:在存储过程中,可以定义变量、条件判断、循环语句等,使得存储过程更加灵活和可控。此外,存储过程还可以使用异常处理机制来捕获和处理异常情况。 总而言之,sqlserver存储过程具有提高性能、提高安全性、降低维护成本、支持事务处理以及改善可维护性的优点。使用存储过程可以有效地提升数据库应用程序的开发效率和运行效率。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值