繁体   English   中英

Vaadin containerFilter选择空字段

[英]Vaadin containerFilter select null field

我正在使用com.vaadin.data.util.sqlcontainer.query.TableQuery用来自MYSQL表的数据填充UI视图。

我只想显示特定字段为null的行,因此原始SQL是:

SELECT * FROM products WHERE monthsLeft IS null;

引用Vaadin文档 ,我正在使用Vaadin SQLContainer对象将此条件设置为sqlContainer.addContainerFilter(new Compare.Equal("monthsLeft ", null));

但这会引发以下错误:

Sep 11, 2014 5:10:13 PM com.vaadin.server.DefaultErrorHandler doDefault SEVERE: java.lang.IllegalArgumentException: You cannot add null parameters using addParamaters(Object). Use addParameters(Object,Class) instead at com.vaadin.data.util.sqlcontainer.query.generator.StatementHelper.addParameterValue(StatementHelper.java:63) at com.vaadin.data.util.sqlcontainer.query.generator.filter.CompareTranslator.getWhereStringForFilter(CompareTranslator.java:32) at com.vaadin.data.util.sqlcontainer.query.generator.filter.QueryBuilder.getWhereStringForFilter(QueryBuilder.java:82) at com.vaadin.data.util.sqlcontainer.query.generator.filter.QueryBuilder.getJoinedFilterString(QueryBuilder.java:92) at com.vaadin.data.util.sqlcontainer.query.generator.filter.QueryBuilder.getWhereStringForFilters(QueryBuilder.java:107) at com.vaadin.data.util.sqlcontainer.query.generator.DefaultSQLGenerator.generateSelectQuery(DefaultSQLGenerator.java:107) at com.vaadin.data.util.sqlcontainer.query.TableQuery.getCount(TableQuery.java:200) at com.vaadin.data.util.sqlcontainer.SQLContainer.updateCount(SQLContainer.java:1142) at com.vaadin.data.util.sqlcontainer.SQLContainer.size(SQLContainer.java:398) at com.vaadin.ui.AbstractSelect.size(AbstractSelect.java:762) at com.vaadin.ui.Table.refreshRenderedCells(Table.java:1628) at com.vaadin.ui.Table.getVisibleCells(Table.java:3921) at com.vaadin.ui.Table.beforeClientResponse(Table.java:3155) at com.vaadin.server.communication.UidlWriter.write(UidlWriter.java:96) at com.vaadin.server.communication.UidlRequestHandler.writeUidl(UidlRequestHandler.java:149) at com.vaadin.server.communication.UidlRequestHandler.synchronizedHandleRequest(UidlRequestHandler.java:97) at com.vaadin.server.SynchronizedRequestHandler.handleRequest(SynchronizedRequestHandler.java:37) at com.vaadin.server.VaadinService.handleRequest(VaadinService.java:1329) at com.vaadin.server.VaadinServlet.service(VaadinServlet.java:236) at javax.servlet.http.HttpServlet.service(HttpServlet.java:848) at org.eclipse.jetty.servlet.ServletHolder.handle(ServletHolder.java:684) at org.eclipse.jetty.servlet.ServletHandler.doHandle(ServletHandler.java:503) at org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:137) at org.eclipse.jetty.security.SecurityHandler.handle(SecurityHandler.java:557) at org.eclipse.jetty.server.session.SessionHandler.doHandle(SessionHandler.java:231)

我希望有一个Compare.IsNull但我看不到

查看源代码,这似乎是不可能的。

此方法没有“ IS NULL”的情况:

@Override
public String getWhereStringForFilter(Filter filter, StatementHelper sh) {
    Compare compare = (Compare) filter;
    sh.addParameterValue(compare.getValue());
    String prop = QueryBuilder.quote(compare.getPropertyId());
    switch (compare.getOperation()) {
    case EQUAL:
        return prop + " = ?";
    case GREATER:
        return prop + " > ?";
    case GREATER_OR_EQUAL:
        return prop + " >= ?";
    case LESS:
        return prop + " < ?";
    case LESS_OR_EQUAL:
        return prop + " <= ?";
    default:
        return "";
    }
}

并且仅从名称为generateDeleteQuery,generateInsertQuery和generateUpdateQuery的三个方法中调用引用的方法(addParameters(Object,Class))。

提交补丁应该不难;)

我开始查看编写补丁的源代码,发现com.vaadin.data.util.filter。 IsNull 解决方案是: sqlContainer.addContainerFilter(new IsNull("monthsLeft"));

暂无
暂无

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

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