SQLFilter基于Azure Service Bus订阅中的系统属性

时间:2016-09-01 23:39:31

标签: c# azure azureservicebus azure-servicebus-topics

我正在设置主题/订阅服务,需要帮助我的SQLFilter的语法,以便我可以访问BrokeredMessage属性,特别是To属性。 SQL筛选器访问消息的系统属性的正确语法是什么?

我有一个使用本教程的工作示例,我可以根据需要发送和接收我的主题/订阅:https://azure.microsoft.com/en-us/documentation/articles/service-bus-queues-topics-subscriptions/

但是,现在我想根据BrokeredMessage的To属性为每个订阅设置SQL过滤器。我所遵循的教程提到可以“创建订阅时,您可以提供对消息属性进行操作的过滤器表达式,包括系统属性(例如,Label)和自定义应用程序属性(例如,StoreName) 。)“

如果我设置自定义属性,例如StoreName,像这样:

message.Properties.Add("StoreName", "TestMe");

并使用SQL过滤器设置订阅:

namespaceManager.CreateSubscription("MyNSTestTopic", "TestSubscription", new SqlFilter("StoreName = 'TestMe'"));

订阅按预期过滤。但是,如果我尝试使用文章中描述的BrokeredMessage对象To属性(或标签),我一直无法使其工作。我尝试了以下SQL过滤器没有运气。访问消息的系统属性的正确语法是什么?

BrokeredMessage message = new BrokeredMessage();
message.To = "TestMe";

namespaceManager.CreateSubscription("MyNSTestTopic", "TestSubscription", new SqlFilter("To = 'TestMe'"));
namespaceManager.CreateSubscription("MyNSTestTopic", "TestSubscription", new SqlFilter("Message.To= 'TestMe'"));
namespaceManager.CreateSubscription("MyNSTestTopic", "TestSubscription", new SqlFilter("MessageTo= 'TestMe'"));
namespaceManager.CreateSubscription("MyNSTestTopic", "TestSubscription", new SqlFilter("messageto= 'TestMe'"));

1 个答案:

答案 0 :(得分:9)

从这篇文章Topic Subscription Filters

  

SQL过滤器 - SqlFilter持有SQL-like condition expression,在代理中根据到达消息的用户定义属性和系统属性进行评估。 所有系统属性(BrokeredMessage class中明确列出的所有属性)都必须在条件表达式中以sys.为前缀。 SQL子集实现测试是否存在属性(EXISTS),测试空值(IS NULL),逻辑NOT / AND / OR,关系运算符,数值算术和与LIKE匹配的简单文本模式。

因此,在您的情况下,您需要在SqlFilter属性上创建sys.To

namespaceManager.CreateSubscription("MyNSTestTopic", "TestSubscription",
    new SqlFilter("sys.To = 'TestMe'"));