我有以下流程参考:<flow name="getAccountsFlow">
<logger message="Type:"#[message.inboundProperties.'http.query.params'.type]"" level="INFO" doc:name="Logger"/>
<db:select config-ref="MySQL_Configuration" doc:name="Database">
<db:parameterized-query><![CDATA[select * from flights_customers where accountType = "#[message.inboundProperties.'http.query.params'.type]"]]></db:parameterized-query>
</db:select>
</flow>
记录器打印变量值:INFO 2019-01-07 16:08:51,270 [[assignment-accounts].accounts-api-httpListenerConfig.worker.03] org.mule.api.processor.LoggerMessageProcessor: Type:"business"
但是查询返回0行。
但是当我使用变量转换器时,可以在查询中以如下形式访问值:<flow name="getAccountsFlow">
<logger message="Type:"#[message.inboundProperties.'http.query.params'.type]"" level="INFO" doc:name="Logger"/>
<set-variable variableName="type" value="#[message.inboundProperties.'http.query.params'.type]" doc:name="Variable"/>
<db:select config-ref="MySQL_Configuration" doc:name="Database">
<db:parameterized-query><![CDATA[select * from flights_customers where accountType = :type]]></db:parameterized-query>
<db:in-param name="type" type="VARCHAR" value="#[flowVars.type]" ></db:in-param>
</db:select>
</flow>
为什么#[message.inboundProperties.'http.query.params'.type]
在查询中不可见?
答案 0 :(得分:1)
这是因为查询中表达式的双引号引起来。尝试删除那些。
但是无论如何,由于注入而使用占位符比较安全,因此我认为我还是要使用第二个示例。