繁体   English   中英

Mule和JDBC查询结果

[英]Mule and JDBC Query Result

我正在使用m子连接到Postgres数据库服务器。 由于使用社区版,因此无法使用数据映射器。 xml转换器的对象未提供良好的格式化结果。 关于如何将jdbc响应转换为良好的解析格式的任何想法。 这是我的配置文件。 这是带有连接器的数据源。

<jdbc:postgresql-data-source name="PostgreSQL_Data_Source"
    user="USERNAME" password="PASSWORD"
    url="jdbc:postgresql://*******:***/*****"
    transactionIsolation="UNSPECIFIED" doc:name="PostgreSQL Data Source" />
    <jdbc:connector name="organizations" dataSource-ref="PostgreSQL_Data_Source"
        validateConnections="true" queryTimeout="-1" pollingFrequency="0"
        doc:name="JDBC">
        <jdbc:query key="getOrganizations" value="SELECT * FROM organization" />
        <jdbc:query key="getOrganizationApplications"
            value="SELECT * FROM organization o,application a,organization_apps oa WHERE o.id=oa.org_id AND a.id=oa.app_id AND o.id=#[flowVars['org_id']]" />
        <jdbc:query key="insertOrganization"
            value="INSERT INTO organization(name, phone, email, address, website) VALUES (?, ?, ?, ?, ?)" />
        <jdbc:query key="getOrganizationUsers"
            value="SELECT * FROM &amp;quot;public&amp;quot;.user WHERE org_id=#[flowVars['org_id']]" />
    </jdbc:connector>

这是流程:

<flow name="logixy-platform-organizations-workflow" doc:name="logixy-platform-organizations-workflow">
        <http:inbound-endpoint exchange-pattern="request-response"
            host="localhost" port="8082" doc:name="HTTP" path="organization" />
        <set-variable variableName="choice"
            value="#[message.inboundProperties['choice']]" doc:name="Set Choice" />
        <choice doc:name="Choice">
            <when expression="#[flowVars['choice'] == '0']">
                <jdbc:outbound-endpoint exchange-pattern="request-response"
                    queryTimeout="-1" doc:name="getAllOrganizations" connector-ref="organizations"
                    queryKey="getOrganizations" />
            </when>
            <when expression="#[flowVars['choice'] == '2']">
                <set-variable variableName="org_id"
                    value="#[(int)(message.inboundProperties['org_id'])]" doc:name="Set Organization ID" />
                <jdbc:outbound-endpoint exchange-pattern="request-response"
                    queryKey="getOrganizationUsers" queryTimeout="-1" connector-ref="organizations"
                    doc:name="getOrganizationUsers" />
            </when>
            <when expression="#[flowVars['choice'] == '1']">
                <set-variable variableName="#['org_id']"
                    value="#[(int)(message.inboundProperties['org_id'])]" doc:name="Set Organization ID" />
                <jdbc:outbound-endpoint exchange-pattern="request-response"
                    queryKey="getOrganizationApplications" queryTimeout="-1"
                    connector-ref="organizations" doc:name="getOrganizationApplications" />
            </when>
        </choice>
        <mulexml:object-to-xml-transformer
            doc:name="Object to XML" />
    </flow>

您应该真正定义“一种很好的解析格式”,但是我想您不喜欢“ entry”,“ string”等字段名称。

您可以使用很多选项来格式化XML,例如:

  1. 使用XSLT将生成的XML转换为您首选的格式
  2. 在Java或Groovy中定义一个与您的返回数据相对应的类,然后
    1. 使用对象到json,然后将json到对象与您的类作为返回类
    2. 将返回数据分配给Java或Groovy中的类的对象

一旦将数据作为自定义对象,object-to-xml-transformer就会打印出更清晰的输出。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM