the execute permission was denied on the object 'procedure1'

happywm 2011-02-05 10:16:33
操作系统:windows server 2003. 数据库SQL server 2005.
由于数据库计算机更新,数据库备份后再在新计算机上恢复,重建用户后,开发的某个程序调用数据库的procedure1失败,说是我的权限没设,可我的权限明明都设了,原程序没问题。
下面是用户名创建过程,希望高手帮看看问题在哪里?
1. 创建服务器登录名user1.
标准数据库是备份后再恢复的“DB1”.
用户角色:public.
用户映射:DB1,public.
2. 修改数据库映射后自动产生用户名user1属性
General: Default schema:dbo
Owned Schemas:db_owner
Securables:添加程序调用的procedure1,权限是Execute,view definition
添加procedure1调用的三个表,权限是权限是select,view definition。
3. 查看procedure1属性--permission,能看到user1
4. 出现错误信息后,曾尝试将三个表和procedure1的权限全开,结果一样。
5. 。。。。。。等高手指导
...全文
734 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
happywm 2011-02-07
  • 打赏
  • 举报
回复
在SSMS中点选和用代码输入有区别吗?不管怎样,我把帐号删除,用代码创建一遍试试吧。
dawugui 2011-02-05
  • 打赏
  • 举报
回复
创建角色,用户,权限

/*--示例说明
示例在数据库pubs中创建一个拥有表jobs的所有权限、拥有表titles的SELECT权限的角色r_test
随后创建了一个登录l_test,然后在数据库pubs中为登录l_test创建了用户账户u_test
同时将用户账户u_test添加到角色r_test中,使其通过权限继承获取了与角色r_test一样的权限
最后使用DENY语句拒绝了用户账户u_test对表titles的SELECT权限。
经过这样的处理,使用l_test登录SQL Server实例后,它只具有表jobs的所有权限。
--*/

USE pubs

--创建角色 r_test
EXEC sp_addrole 'r_test'

--授予 r_test 对 jobs 表的所有权限
GRANT ALL ON jobs TO r_test
--授予角色 r_test 对 titles 表的 SELECT 权限
GRANT SELECT ON titles TO r_test

--添加登录 l_test,设置密码为pwd,默认数据库为pubs
EXEC sp_addlogin 'l_test','pwd','pubs'

--为登录 l_test 在数据库 pubs 中添加安全账户 u_test
EXEC sp_grantdbaccess 'l_test','u_test'

--添加 u_test 为角色 r_test 的成员
EXEC sp_addrolemember 'r_test','u_test'

--拒绝安全账户 u_test 对 titles 表的 SELECT 权限
DENY SELECT ON titles TO u_test

/*--完成上述步骤后,用 l_test 登录,可以对jobs表进行所有操作,但无法对titles表查询,虽然角色 r_test 有titles表的select权限,但已经在安全账户中明确拒绝了对titles的select权限,所以l_test无titles表的select权限--*/

--从数据库 pubs 中删除安全账户
EXEC sp_revokedbaccess 'u_test'

--删除登录 l_test
EXEC sp_droplogin 'l_test'

--删除角色 r_test
EXEC sp_droprole 'r_test'
飘零一叶 2011-02-05
  • 打赏
  • 举报
回复
--测试数据库
use master
create database text

--创建存储过程
use text
create proc procedure1
as
select GETDATE()

--创建登录名
use master
create login user1 with password='123456'

--创建用户
use text
CREATE USER user1 FOR LOGIN user1 WITH DEFAULT_SCHEMA=[dbo]

--为用户授予执行procedure1的权限
use text
grant execute on procedure1 to user1

--登陆user1
exec procedure1
/*
(无列名)
2011-02-05 17:09:29.623
*/
飘零一叶 2011-02-05
  • 打赏
  • 举报
回复
grant execute on procedure1 to user1
内容概要:本文围绕“基于超局部模型与自抗扰ESO观测器的无模型预测电流控制改进策略”展开研究,提出一种结合超局部模型(ULM)与扩张状态观测器(ESO)的无模型预测电流控制(MFPCC)改进方法,旨在提升永磁同步电机(PMSM)电流环的动态响应性能与抗干扰能力。该策略利用超局部模型对系统行为进行局部逼近,避免依赖精确数学模型,同时引入自抗扰控制中的ESO实时观测并补偿系统内外部扰动,有效抑制参数摄动、负载变化及模型不确定性带来的影响。研究通过Simulink搭建完整的控制系统仿真模型,对传统MFPCC与所提改进策略进行对比分析,验证了新方法在电流跟踪精度、响应速度和鲁棒性方面的优越性。; 适合人群:具备电机控制、现代控制理论及Simulink仿真基础的电气工程、自动化及相关专业的研究生、科研人员及工程技术人员。; 使用场景及目标:①用于高性能电机驱动系统中电流环控制器的设计与优化;②为无模型控制与自抗扰控制的融合应用提供技术参考;③支撑相关课题的仿真验证、论文复现与创新方法研究。; 阅读建议:建议读者结合Simulink仿真模型深入理解控制结构与参数整定过程,重点关注ESO的观测性能与扰动补偿机制,并可通过改变负载条件、参数偏差等工况进行鲁棒性测试,进一步掌握该改进策略的核心优势与适用边界。

34,876

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧