zoukankan      html  css  js  c++  java
  • sql server service broker中调用存储过程执行跨库操作,不管怎么设置都一直提示 服务器主体 "sa" 无法在当前安全上下文下访问数据库 "dbname"。

    用sql server自带的消息队列service borker,调用存储过程中,执行了一个跨库的操作,先是用了一个用户,权限什么都给够了,但是一直提示 服务器主体 "user" 无法在当前安全上下文下访问数据库 "dbname"。

    想着是架构方面的问题,换sa还是不行。查到微软的一篇文章 提示需要开数据库的 ALTER DATABASE current_db SET TRUSTWORTHY ON 

    我把跨的那个库设置了还是不行。最后自己写测试代码,代码如下:

    create database test1
    
    create database test2
    
    use test2
    create table t_1 (id int ,ddate date )
    insert into t_1 (id,ddate) values(1,GETDATE())
    
    use test1 
    
    create proc p_test
    WITH EXECUTE AS OWNER
    as
    begin
     select GETDATE()
     select * from test2..t_1
    end
    
    exec  p_test
    
    
    
    
    ALTER DATABASE test1 SET TRUSTWORTHY on
    ALTER DATABASE test2 SET TRUSTWORTHY ON

    两个库都 SET TRUSTWORTHY on  却可以了。。。。。。折腾了一天时间。。。。。。。。。。

    EXECUTE AS OWNER 设置会话的执行上下文。队列里去不掉,要解决有两个方法 ,上面是方法其一,其二是用证书。。。。。。。

    查看看到哪些数据库开了trustworthy属性,命令如下:
    SELECT name, database_id, is_trustworthy_on FROM sys.databases

    授权用户访问,命令如下:

    ALTER AUTHORIZATION ON DATABASE::数据库名 TO [用户名]

  • 相关阅读:
    算法--判断数组中是否有重复值
    算法--小范围排序
    Spark性能调优之JVM调优
    算法-java代码实现基数排序
    算法-java代码实现计数排序
    算法-java代码实现希尔排序
    算法-java代码实现堆排序
    Kafka集群的搭建
    深度学习必备包
    Keras 学习之旅(一)
  • 原文地址:https://www.cnblogs.com/davidhou/p/5885228.html
Copyright © 2011-2022 走看看