0

我想从数据库中读取并创建一个 CSV 文件。为了做到这一点,我正在使用camel-jdbccamel-bindy

首先,我使用 SELECT 语句设置正文。

SELECT  [vendor],
        [ean],
        [itemid] AS itemId,
        [quantity]
FROM [dbo].[ElectronicDeliveryNotes]

然后我调用 jdbc 组件

<to uri="jdbc:dataSource?outputType=SelectList&amp;outputClass=com.xxx.Model"/> 

这将返回一个模型列表。模型类是

@CsvRecord(separator = ";", generateHeaderColumns = true, crlf = "UNIX")
public class Model2 {

    @DataField(pos = 1, columnName = "A_Liererant")
    private String vendor;
    @DataField(pos = 2, columnName = "F_EAN")
    private String ean;
    @DataField(pos = 3, columnName = "G_Lief. Artikelnummer")
    private String itemId;
    @DataField(pos = 4, columnName = "H_Menge")
    private BigDecimal quantity;

    //getters setters 

我收到以下错误:

java.lang.IllegalArgumentException: Cannot map all properties to bean of type class com.xxx.Model2. There are 1 unmapped properties. {itemid=11.0441-5402.2}

据我了解,问题在于模型属性的命名。我尝试并工作的一种解决方案是重命名模型itemId => itemid。这会起作用,但我没有使用 Java 命名约定。

你知道如何在不重命名属性的情况下克服这个问题吗?

我也尝试了以下方法,但没有奏效。

 @DataField(pos = 3, columnName = "G_Lief. Artikelnummer", name = "itemid")
    private String itemId;
4

1 回答 1

1

我没有发现您的代码结构有任何问题。

如果您想要完成的是从表中检索并根据您的Model2类将其结果导出到 CSV,我可能会建议使用camel-sql。可能是这样的:

@Override
protected RoutesBuilder createRouteBuilder() throws Exception {
    return new RouteBuilder() {

        @Override
        public void configure() throws Exception {
            getContext().getComponent("sql", SqlComponent.class).setDataSource(db);
            BindyCsvDataFormat camelDataFormat = new BindyCsvDataFormat(Model2.class);

            from("sql:select vendor, ean, itemid as itemId, quantity from ElectronicDeliveryNotes?outputType=SelectList&outputClass=com....model.Model2")
                    .marshal(camelDataFormat)
                    .log("the body:\n${body}")
                    .to("mock:result");
        }
    };
}

您从表中轮询数据,对其进行编组,然后将消息发送到其他队列。我已经运行了一些测试以确保查询结果可以转换为 CSV,并且只要您保持字段名称等于您的属性,似乎就不会出错。(旁注:在我的测试中,即使没有别名也一切正常)。

但是,测试您的代码时,我遇到了同样的错误。也许你需要实现beanRowMapper

在使用 outputClass 时使用自定义的 org.apache.camel.component.jdbc.BeanRowMapper。默认实现将小写行名并跳过下划线和破折号。例如,“CUST_ID”映射为“custId”。

我猜这就是您陷入此错误的原因:

java.lang.IllegalArgumentException: Cannot map all properties to bean of type class com.xxx.Model2. There are 1 unmapped properties. {itemid=11.0441-5402.2}

尝试将别名重命名为ITEM_ID.

于 2017-12-18T20:57:28.720 回答