启用Service Broker

授予权限
必须在MSDB数据库重的QueryNotificationService服务上翔Guest用户授予发送权限
USE MSDB
GRANT SEND ON SERVICE::
[http://schemas.microsoft.com/SQL/Notifications/QueryNotificationService]
TO GUEST

在数据库服务器上启用CLR
在一个消息到达服务队列时,一个包含.NET代码的存储过程sp_DispatcherProc将使用一个队列来派发该消息,因此必须在该sql Server实例上启用CLR
USE MASTER
EXEC sp_configure 'clr enabled'1
RECONFIGURE

启用Service Broker
USE MASTER
ALTER DATABASE NORTHWIND set ENABLE_BROKER
--验证是否能启用
go
Select DATABASEpRoPERTYEX('NorthwInd','IsBrokerEnabled')

转载于:https://www.cnblogs.com/zwl12549/archive/2007/08/24/867698.html

我根据你上面给的提示 修改了下代码 using System; using System.Data; using System.Data.SqlClient; using System.Net.Http; class Program { static string connectionString = "server=10.20.10.11;user=sa;password=P@ssw0rd; database=QuickData;"; static string tableName = "dbo.sys_andon"; // 使用两段式名称 // 记录最后处理的ID,避免重复处理 static int lastProcessedId = 0; static void Main() { // 确保数据库启用 Service Broker EnableServiceBroker(); SqlDependency.Start(connectionString); Console.WriteLine("SqlDependency 监听已启动..."); // 初始注册监听 RegisterSqlDependency(); Console.WriteLine("监听中,按任意键退出..."); Console.ReadKey(); SqlDependency.Stop(connectionString); } static void EnableServiceBroker() { try { using (var conn = new SqlConnection(connectionString)) { conn.Open(); var cmd = new SqlCommand( "IF NOT EXISTS(SELECT * FROM sys.databases WHERE name = DB_NAME() AND is_broker_enabled = 1) " + "BEGIN ALTER DATABASE CURRENT SET ENABLE_BROKER WITH ROLLBACK IMMEDIATE; END", conn); cmd.ExecuteNonQuery(); Console.WriteLine("已确保 Service Broker 启用"); } } catch (Exception ex) { Console.WriteLine($"启用 Service Broker 失败: {ex.Message}"); } } static void RegisterSqlDependency() { using (var conn = new SqlConnection(connectionString)) { conn.Open(); // 创建符合要求的查询 var cmd = new SqlCommand( $"SELECT term_no, id FROM {tableName} WHERE tenant_code<>'1'", conn); // 创建依赖 var dependency = new SqlDependency(cmd); dependency.OnChange += OnDatabaseChange; // 必须执行命令才能开始监听 using (var reader = cmd.ExecuteReader()) { // 处理初始查询结果(如果有) while (reader.Read()) { ProcessRecord(reader); } } } } private static void OnDatabaseChange(object sender, SqlNotificationEventArgs e) { var dependency = (SqlDependency)sender; dependency.OnChange -= OnDatabaseChange; // 取消旧订阅 Console.WriteLine($"检测到变更! 类型: {e.Type}, 来源: {e.Source}, 信息: {e.Info}"); if (e.Type == SqlNotificationType.Change && (e.Info == SqlNotificationInfo.Insert || e.Info == SqlNotificationInfo.Update)) { // 重新注册监听 RegisterSqlDependency(); } else { Console.WriteLine($"非插入/更新变更,忽略。类型: {e.Type}, 信息: {e.Info}"); } } private static void ProcessRecord(SqlDataReader reader) { try { string termNo = reader["term_no"].ToString(); // 调用 API using (var client = new HttpClient()) { // 注意:实际使用中应使用异步方法,这里为了简化使用 Result var response = client.GetAsync( $"https://localhost:7270/api/tts?text={Uri.EscapeDataString(termNo)}&lang=zh-cn" ).Result; Console.WriteLine($"API 调用状态: {response.StatusCode}"); if (response.IsSuccessStatusCode) { Console.WriteLine("API 调用成功"); } } } catch (Exception ex) { Console.WriteLine($"处理记录失败: {ex.Message}"); } } } 但是运行后新增数据 也没有正常调用api 控制台是正常的已确保 Service Broker 启用 SqlDependency 监听已启动... 监听中,按任意键退出...
最新发布
07-25
SQL Server 2005 的一个主要成就是可以实现可靠、可扩展且功能完善的数据库应用程序。与 .NET Framework 2.0 公共语言运行库 (CLR) 的集成使开发人员可以将重要的业务逻辑与存储过程合并,而 T-SQL 和 XML 中的新增功能扩展了数据操作的可用范围以及开发人员可用的存储功能。另一个重要功能是 SQL Server Service Broker,它为数据库应用程序增加了可靠、可扩展、分布式异步功能。 为什么要编写异步排队操作? 在开发 SQL Server 2005 时,我们与成功开发过大型可扩展数据库应用程序的人员进行了交谈。结果发现他们几乎所有的应用程序中都有一个或多个操作是以异步排队方式执行的。股票交易系统中的结算活动是排队的,这样可以在后台进行结算,在前端处理其他交易。订单输入系统中的发货信息放在一个排队中,稍后将由另一台服务器(通常位于其他位置)上运行的发货系统读取。旅行预订系统在客户填写完路线后再进行实际的预订,并在预订完成后发送确认电子邮件。在所有这些示例中,许多工作都是通过异步方式完成的,从而提高了系统的响应速度,因此用户无须等待工作完成就可以收到响应。 在大多数大型系统中,经过仔细分析后都可以发现,许多处理都可以通过异步方式完成。虽然应用程序中的排队任务无须立即完成,但系统必须确保这些任务能够可靠地完成。Service Broker 使异步排队任务的执行可靠并且易于实现。 使应用程序中的部分任务异步执行的另一个优势是这些任务的处理工作可以在资源可用时完成。如果订单输入系统中的发货任务可以从队列中执行,发货系统就无需具有处理峰值订单负载的能力。在许多订单输入系统中,峰值订单率可能是平均订单率的两倍或三倍。由于订单输入系统必须具有处理峰值负载的能力,因此大量处理能力在很大一部分时间内都处于闲置状态。如果在出现峰值时对异步任务进行排队并在空闲时执行,将显著提高系统的利用率。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值