如何在mule studio应用程序中访问jdbc端点中的流变量

如何在mule studio应用程序中访问jdbc端点中的流变量,mule,Mule,例外情况: 根异常堆栈跟踪: java.lang.IllegalArgumentException:未找到SQL语句的SQL策略:#[flowVars['query']] 位于com.mulesoft.mule.transport.jdbc.sqlstrategy.EESqlStatementStrategyFactory.create(EESqlStatementStrategyFactory.java:109) 位于org.mule.transport.jdbc.JdbcMessageDis

例外情况:

根异常堆栈跟踪: java.lang.IllegalArgumentException:未找到SQL语句的SQL策略:#[flowVars['query']] 位于com.mulesoft.mule.transport.jdbc.sqlstrategy.EESqlStatementStrategyFactory.create(EESqlStatementStrategyFactory.java:109) 位于org.mule.transport.jdbc.JdbcMessageDispatcher.doSend(JdbcMessageDispatcher.java:69) 位于org.mule.transport.AbstractMessageDispatcher.process(AbstractMessageDispatcher.java:81) +3个以上(为所有内容设置调试级别日志或“-Dmule.verbose.exceptions=true”)

这里我想基于输入动态构建jdbc查询

json数据{“companyId”:“1”,“storeId”:“1”}
请帮助我。

尝试对jdbc动态出站端点使用类似以下内容:

<jdbc-ee:mysql-data-source name="MySQL_Data_Source" user="root" password="root" url="jdbc:mysql://localhost:3306/test" transactionIsolation="UNSPECIFIED" doc:name="MySQL Data Source"/>
<jdbc-ee:connector name="test" dataSource-ref="MySQL_Data_Source" validateConnections="true" queryTimeout="-1" pollingFrequency="0" doc:name="Database"/>
<data-mapper:config name="DataMapper" transformationGraphPath="mapper.grf" doc:name="DataMapper"/>
<flow name="EmployeeListFlow1" doc:name="EmployeeListFlow1">
    <http:inbound-endpoint exchange-pattern="request-response" host="localhost" port="8082" doc:name="HTTP" path="employeelist"/>
    <json:json-to-object-transformer doc:name="JSON to Object" returnClass="java.util.Map"/>
    <choice doc:name="Choice">
        <when expression="payload.storeId == null || payload.storeId &lt;= 0 ">
            <set-variable variableName="query" value="select e.employeeid,e.companyid,e.firstName,e.lastName from employees e where companyid = #[message.payload.companyId]" doc:name="CompanyId"/>
        </when>
        <otherwise>
            <set-variable variableName="query" value="select e.employeeid,e.companyid,e.firstName,e.lastName from employees e where employeeid in (select employeeid from employeestores where storeid =#[message.payload.storeId] )" doc:name="StoreId"/>
        </otherwise>
    </choice>
    <jdbc-ee:outbound-endpoint exchange-pattern="request-response"  queryTimeout="-1" doc:name="EmployeeListFetch" connector-ref="Theatro" queryKey="employees_list">
        <jdbc-ee:query key="employees_list" value="#[flowVars['query']]"/>
    </jdbc-ee:outbound-endpoint>
    <json:object-to-json-transformer doc:name="Object to JSON"/>
</flow>


HTH

这里有两个错误,
在选项中,表达式缺少
[]

类似于

接下来,您的查询应该是这样的:-

<outbound-endpoint address="jdbc://select * from ${datasource.table} #[variable:where-statement]" exchange-pattern="request-response"/>

其中
#[message.payload.storeId]
应该在
'
中,因为storeId是一个字符串

您尝试过什么吗?没有。我只尝试过使用此代码
select e.employeeid,e.companyid,e.firstName,e.lastName from employees e where employeeid in (select employeeid from employeestores where storeid ='#[message.payload.storeId]' )