为了账号安全,请及时绑定邮箱和手机立即绑定

使用JSF / Java EE从数据库进行实时更新

使用JSF / Java EE从数据库进行实时更新

幕布斯6054654 2019-08-12 17:28:24
使用JSF / Java EE从数据库进行实时更新我有一个应用程序在以下环境中运行。GlassFish Server 4.0JSF 2.2.8-02PrimeFaces 5.1决赛PrimeFaces Extension 2.1.0OmniFaces 1.8.1EclipseLink 2.5.2具有JPA 2.1MySQL 5.6.11JDK-7u11有几个公共页面从数据库中延迟加载。一些CSS菜单显示在模板页面的标题上,如显示类别/子类别特征,最畅销,新到达等产品。CSS菜单根据数据库中的各种产品类别从数据库动态填充。这些菜单填充在每个页面加载上,这是完全没有必要的。其中一些菜单需要复杂/昂贵的JPA标准查询。目前,填充这些菜单的JSF托管bean是视图范围的。它们都应该是应用程序作用域,在应用程序启动时只加载一次,并且只有在更新/更改相应数据库表(类别/子类别/产品等)中的某些内容时才更新。我做了一些尝试来理解WebSokets(从未尝试过,对WebSokets来说是全新的),就像这样和这个。他们在GlassFish 4.0上运行良好,但它们不涉及数据库。我仍然无法正确理解WebSokets的工作方式。特别是涉及数据库时。在这种情况下,当更新/删除/添加到相应的数据库表时,如何通知关联的客户端并使用数据库中的最新值更新上述CSS菜单?一个简单的例子很棒。
查看完整描述

3 回答

?
慕娘9325324

TA贡献1783条经验 获得超4个赞

PrimeFaces具有轮询功能,可自动更新组件。在以下示例中,<h:outputText>将每3秒自动更新一次<p:poll>

如何通知关联的客户端并使用数据库中的最新值更新上述CSS菜单?

创建一个类似于process()选择菜单数据的侦听器方法。 <p:poll>将自动更新您的菜单组件。

<h:form>
    <h:outputText id="count"
                  value="#{AutoCountBean.count}"/> <!-- Replace your menu component-->

    <p:poll interval="3" listener="#{AutoCountBean.process}" update="count" /></h:form>
@ManagedBean@ViewScopedpublic class AutoCountBean implements Serializable {

    private int count;

    public int getCount() {
        return count;
    }

    public void process() {
        number++; //Replace your select data from db.
    }}


查看完整回答
反对 回复 2019-08-12
  • 3 回答
  • 0 关注
  • 513 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信