我正在设置主题/订阅服务,需要帮助我的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'"));
答案 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'"));