Warning: file_get_contents(/data/phpspider/zhask/data//catemap/7/jsf/5.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
延迟加载的primefaces数据表在SQL语句完成执行之前更新_Sql_Jsf_Jsf 2_Datatable_Primefaces - Fatal编程技术网

延迟加载的primefaces数据表在SQL语句完成执行之前更新

延迟加载的primefaces数据表在SQL语句完成执行之前更新,sql,jsf,jsf-2,datatable,primefaces,Sql,Jsf,Jsf 2,Datatable,Primefaces,当用于更新\从此表中删除实体的SQL语句完成执行之前,primefaces数据表被更新时,我遇到了一个问题 01:08:13,255 INFO [reg.data.model.LazyEventDataModelMod] - Loading the lazy event data between 0 and 10 01:08:13,256 DEBUG [org.hibernate.SQL] - select count(*) as col_0_0_ fr

当用于更新\从此表中删除实体的SQL语句完成执行之前,primefaces数据表被更新时,我遇到了一个问题

01:08:13,255 INFO [reg.data.model.LazyEventDataModelMod]  - Loading the lazy event data between 0 and 10 
01:08:13,256 DEBUG [org.hibernate.SQL]  - 
    select
        count(*) as col_0_0_ 
    from
        events event0_ limit ? 
01:08:13,394 DEBUG [org.hibernate.SQL]  - 
    delete 
    from
        events 
    where
        id=? 
问题是实体管理器没有返回任何东西来表示它已成功执行了delete\update查询

我使用JSF 2、Weld 1.1.5.Final、Primefaces 3.0.1、Seam persistence/transaction/Weddle 3.0.1.Final。
服务器是Tomcat7

下面是调用控制器bean上的操作的按钮的代码:

<p:commandButton id="deleteButton" value="#{msg.delete}"
    icon="ui-icon-trash" update=":events_form :messages"
    actionListener="#{eventController.delete()}" />

<p:commandButton id="refreshButton" value="#{msg.refresh}"
    icon="ui-icon-refresh" update=":events_form :messages" />
dao中的deleteById()方法:

public void delete(T entity) {
        if (em == null)
            init();
        log.debugf("removing %s instance", simpleName);

        entity = em.merge(entity);

// The problem lies here - em.remove() does not return any value to indicate success/failure, so the control is released before the SQL statements finish execution 

em.remove(entity);
}
数据表:

<p:dataTable id="event_list" value="#{eventController.lazyModel}"
                var="event" rowKey="#{event.id}" paginator="true" rows="20"
                selection="#{eventController.selEvent}" selectionMode="single"
                onRowSelectUpdate="content,messages"
                onRowEditUpdate="content,messages"
                paginatorTemplate="{CurrentPageReport} {FirstPageLink} {PreviousPageLink} {PageLinks} {NextPageLink} {LastPageLink} {RowsPerPageDropdown}"
                rowsPerPageTemplate="10,25,50,100">

LazyDataModel类:

public class LazyEventDataModel extends LazyDataModel<Event> {

private static final long serialVersionUID = 2386224274507659474L;

private EventDAO dao;

private Logger log = Logger.getLogger(LazyEventDataModel.class);

private List<Event> data;

public LazyEventDataModel() {
    dao = new EventDAO();
}

@Override
public Event getRowData(String rowKey) {
    return dao.find(Long.parseLong(rowKey));
}

@Override
public Object getRowKey(Event event) {
    return event.getId();
}

@Override
public List<Event> load(int first, int pageSize, String sortField,
        SortOrder sortOrder, Map<String, String> filters) {

    if (sortField == null || "".equals(sortField)) {
        sortField = "event_date";
        sortOrder = SortOrder.DESCENDING;
    }

    if (sortField.equals("date"))
        sortField = "event_date";

    // Get the paginated and sorted data
    data = dao.findPageObjects(Event.class, first, pageSize, sortField,
            sortOrder, filters);

    log.infof("Loading the lazy event data between " + first + " and "
            + (first + pageSize));

    // Set the row count
    this.setRowCount(Global.safeLongToInt(dao.count()));

    return data;
}
}
公共类LazyEventDataModel扩展了LazyDataModel{
私有静态最终长serialVersionUID=2386224274507659474L;
私事道道;
私有记录器log=Logger.getLogger(LazyEventDataModel.class);
私人名单数据;
公共LazyEventDataModel(){
dao=neweventdao();
}
@凌驾
公共事件getRowData(字符串rowKey){
返回dao.find(Long.parseLong(rowKey));
}
@凌驾
公共对象getRowKey(事件){
return event.getId();
}
@凌驾
公共列表加载(int first,int pageSize,String sortField,
排序器(排序器、映射过滤器){
if(sortField==null | |“”.equals(sortField)){
sortField=“事件日期”;
sortOrder=sortOrder.downing;
}
如果(sortField.equals(“日期”))
sortField=“事件日期”;
//获取分页和排序的数据
data=dao.findPageObjects(Event.class,first,pageSize,sortField,
分拣机、过滤器);
log.infof(“在“+first+”和”之间加载惰性事件数据”
+(第一个+页面大小);
//设置行计数
this.setRowCount(Global.safeLongToInt(dao.count());
返回数据;
}
}

我现在能想到的唯一解决方案是在调用dao.delete(getSelEvent())之后添加计时器,并在该计时器之后刷新数据模型。

commandButton的update属性也必须包括datatable。一旦ajax调用完成,更新中设置的任何内容都将发生。考虑到您没有创建单独的线程来执行数据库操作(这将使ajax请求几乎立即完成),请执行以下操作

但有一点需要注意:由于某些原因,在update属性中引用datatable的id不起作用。我通常只是用一个panelGroup包装它,然后告诉按钮更新panelGroup。大概是这样的:

<p:commandButton value="Delete" actionListener="#{someBean.delete}" update="panel">
</p:commandButton>
<h:panelGroup id="panel">
<p:dataTable id="event_list" value="#{eventController.lazyModel}"
                var="event" rowKey="#{event.id}" paginator="true" rows="20"
                selection="#{eventController.selEvent}" selectionMode="single"
                onRowSelectUpdate="content,messages"
                onRowEditUpdate="content,messages"
                paginatorTemplate="{CurrentPageReport} {FirstPageLink} {PreviousPageLink} {PageLinks} {NextPageLink} {LastPageLink} {RowsPerPageDropdown}"
                rowsPerPageTemplate="10,25,50,100">

...

</h:panelGroup>

...

请注意,primeFaces按钮组件默认使用ajax,因此您根本不需要jsf2 ajax标记。

不幸的是,正如我所怀疑的,问题在于在SQL语句之前执行ajax调用。我将重新表述我的问题并添加日志。关于通过其他组件引用表的信息很有用,但通常我只是更新整个表单。
<p:commandButton value="Delete" actionListener="#{someBean.delete}" update="panel">
</p:commandButton>
<h:panelGroup id="panel">
<p:dataTable id="event_list" value="#{eventController.lazyModel}"
                var="event" rowKey="#{event.id}" paginator="true" rows="20"
                selection="#{eventController.selEvent}" selectionMode="single"
                onRowSelectUpdate="content,messages"
                onRowEditUpdate="content,messages"
                paginatorTemplate="{CurrentPageReport} {FirstPageLink} {PreviousPageLink} {PageLinks} {NextPageLink} {LastPageLink} {RowsPerPageDropdown}"
                rowsPerPageTemplate="10,25,50,100">

...

</h:panelGroup>