在Windows Server 2008 R2 Server中,连接其他服务器的数据库遇到“未启用当前数据库的 SQL Server Service Broker,因此查询通知不受支持。如果希望使用通知,请为此数据库启用 Service Broker ”

时间:2022-04-19 08:43:03

项目代码和数据库部署在不同的Windows Server 2008 R2 Server中,错误日志显示如下:

"未启用当前数据库的 SQL Server Service Broker,因此查询通知不受支持。如果希望使用通知,请为此数据库启用 Service Broker。"

SQL Server Service Broker介绍:

SQL Server Service Broker 为消息和队列应用程序提供 SQL Server 数据库引擎本机支持。这使开发人员可以轻松地创建使用数据库引擎组件在完全不同的数据库之间进行通信的复杂应用程序。开发人员可以使用 Service Broker 轻松生成可靠的分布式应用程序。使用 Service Broker 的应用程序开发人员无需编写复杂的内部通信和消息,即可跨多个数据库分发数据工作负荷。因为 Service Broker 会处理会话上下文中的通信路径,所以这就减少了开发和测试工作。同时还提高了性能。例如,支持网站的前端数据库可以记录信息并将进程密集型任务发送到后端数据库以进行排队。Service Broker 确保在事务上下文中管理所有任务以确保可靠性和技术一致性。

解决方案:

1、在数据库新建查询,输入:

SELECT is_broker_enabled FROM sys.databases WHERE name = 'MyDB'        --‘MyDB’即我的数据库名字

查询结果:

在Windows Server 2008 R2 Server中,连接其他服务器的数据库遇到“未启用当前数据库的 SQL Server Service Broker,因此查询通知不受支持。如果希望使用通知,请为此数据库启用 Service Broker ”

需要把值设为1

2、再执行下面的语句:

ALTER DATABASE MyDB SET NEW_BROKER WITH ROLLBACK IMMEDIATE;
ALTER DATABASE MyDB SET ENABLE_BROKER;

查询结果如下:

在Windows Server 2008 R2 Server中,连接其他服务器的数据库遇到“未启用当前数据库的 SQL Server Service Broker,因此查询通知不受支持。如果希望使用通知,请为此数据库启用 Service Broker ”

这时再运行程序,就不会这个错误了。

注:这里仅是记录解决问题的过程。