- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
于 2014 年 12 月 2 日修订 - persistence.xml 和 eclipselink/mysql 的 Wildfly 配置于 2014 年 12 月 2 日修订 - 更好的问题信息、建议的完整代码和屏幕截图。
我有两个一对多关系的 MYSQL 表。我使用绑定(bind)到关联 JPAContainer(productsContainer、pricesContainer)的两个表(tbl_products、tbl_prices)在 Vaadin 中显示它们。在 tbl_prices 中,我使用 ratesContainer.addNestedContainerProperty() 显示第一个表中的字段。
问题是,当我更改 tbl_products 中的 QTY 字段值时,更改会立即反射(reflect)到数据库中,但是 tbl_prices 中的嵌套属性永远不会知道更改,直到浏览器刷新。 (pricesContainer.getItem(itemId).getProperty("product.qty") 返回旧值)。帖子末尾的数量更新后屏幕截图清楚地显示了这一点。
tbl_prices.refreshRowCache() 和 ratesContainer.refresh() 没有帮助,尽管容器刷新应该刷新数据库中的值)
如果您能提供有关如何解决此问题的帮助,我将不胜感激。无法在 vaadin.com 论坛上获得答案。以下是实体的配置方式:
@Entity
@Table(name="products")
@NamedQuery(name="Product.findAll", query="SELECT p FROM Product p")
public class Product implements Serializable {
private static final long serialVersionUID = 1L;
@Id
@GeneratedValue(strategy=GenerationType.IDENTITY)
@Column(unique=true, nullable=false)
private int id;
@Column(nullable=false, length=255)
private String name;
@Column(nullable=false)
private int qty;
//bi-directional many-to-one association to Price
@OneToMany(mappedBy="product")
private List<Price> prices;
... constructor, getters and setters
}
@Entity
@Table(name="prices")
@NamedQuery(name="Price.findAll", query="SELECT p FROM Price p")
public class Price implements Serializable {
private static final long serialVersionUID = 1L;
@Id
@GeneratedValue(strategy=GenerationType.IDENTITY)
@Column(unique=true, nullable=false)
private int id;
@Column(nullable=false, length=255)
private String description;
@Column(nullable=false, precision=10, scale=2)
private BigDecimal price;
//bi-directional many-to-one association to Product
@ManyToOne
@JoinColumn(name="prodid", nullable=false)
private Product product;
@Transient
private BigDecimal value;
public BigDecimal getValue() {
return this.price.multiply(new BigDecimal(product.getQty()));
}
... constructor, getters and setters
}
public class UI_Tables_Test extends CustomComponent {
public static final String PERSISTENCE_UNIT = "vaadin_sandbox";
public JPAContainer<Product> productsContainer;
public JPAContainer<Price> pricesContainer;
private FieldGroup formFieldGroup;
public UI_Tables_Test() {
buildMainLayout();
setCompositionRoot(mainLayout);
// Containers
productsContainer = JPAContainerFactory.make(Product.class, PERSISTENCE_UNIT);
pricesContainer = JPAContainerFactory.make(Price.class, PERSISTENCE_UNIT);
pricesContainer.addNestedContainerProperty("product.*");
// Tables
tbl_products.setContainerDataSource(productsContainer);
tbl_products.setSelectable(true);
tbl_products.setImmediate(true);
tbl_prices.setContainerDataSource(pricesContainer);
tbl_prices.setSelectable(true);
tbl_prices.setImmediate(true);
// Columns
tbl_products.setVisibleColumns(new Object[] {"id","name", "qty"});
tbl_prices.setVisibleColumns(new Object[] {"id", "product.name", "product.qty", "price", "value"});
// Form
formFieldGroup = new FieldGroup(new BeanItem<Product>(new Product()));
formFieldGroup.setBuffered(false);
formFieldGroup.bind(tf_name, "name");
formFieldGroup.bind(tf_qty, "qty");
// ValueChangeListener to set form data source
tbl_products.addValueChangeListener(new Property.ValueChangeListener() {
private static final long serialVersionUID = 7133249924369468095L;
@Override
public void valueChange(ValueChangeEvent event) {
Object selectedrow = event.getProperty().getValue();
if (selectedrow != null) {
formFieldGroup.setItemDataSource(tbl_products.getItem(selectedrow));
}
}
});
// Property ValueChangeListener to refresh Prices table
productsContainer.getItem(2).getItemProperty("qty").addValueChangeListener(new Property.ValueChangeListener() {
@Override
public void valueChange(ValueChangeEvent event) {
refreshTable2();
}
});
}
public void refreshTable2() {
// trying various refresh methodologies
pricesContainer.refresh();
pricesContainer.getEntityProvider().refreshEntity(pricesContainer.getItem(3).getEntity());
tbl_prices.refreshRowCache();
// trying removing and adding nested container property again
pricesContainer.removeContainerProperty("product.*");
pricesContainer.addNestedContainerProperty("product.*");
// trying resetting table2 container data source
tbl_prices.setContainerDataSource(pricesContainer);
pricesContainer.addNestedContainerProperty("product.*");
tbl_prices.setVisibleColumns(new Object[] {"id", "product.name", "product.qty", "price", "value"});
// popup message to display the values read from the containers
String msg = "Product container Qty= " +
String.valueOf(productsContainer.getItem(2).getEntity().getQty()) + "\n" +
"Price container Qty= " +
String.valueOf(pricesContainer.getItem(3).getEntity().getProduct().getQty()) + "\n" +
pricesContainer.getContainerProperty(3, "product.qty");
Notification.show("Test", msg, Notification.Type.ERROR_MESSAGE);
}
... build layout
}
这里有两个屏幕截图(Dropbox 链接,因为信誉点不足以发布图像)
数量更新前: https://www.dropbox.com/s/ej459r0v80popsb/before_quantity_update.png?dl=0
数量更新后: https://www.dropbox.com/s/ryl358pyymguonl/after_quantity_update.png?dl=0
这是 persistence.xml 和相关的 Wildfly 配置
persistence.xml
---------------
<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.1"
xmlns="http://xmlns.jcp.org/xml/ns/persistence"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/persistence http://xmlns.jcp.org/xml/ns/persistence/persistence_2_1.xsd">
<persistence-unit name="vaadin_sandbox" transaction-type="RESOURCE_LOCAL">
<provider>org.eclipse.persistence.jpa.PersistenceProvider</provider>
<non-jta-data-source>java:/jdbc/vaadin_sandbox</non-jta-data-source>
<exclude-unlisted-classes>false</exclude-unlisted-classes>
<shared-cache-mode>NONE</shared-cache-mode>
<properties>
<property name="eclipselink.deploy-on-startup" value="True" />
<property name="eclipselink.target-server" value="JBoss"/>
<property name="eclipselink.logging.level" value="FINE" />
</properties>
</persistence-unit>
</persistence>
wildfly config:
--------------
eclipselink.jar in /usr/local/wildfly-8.1.0.Final/modules/system/layers/base/org/eclipse/persistence/main
corresponding module.xml
<module xmlns="urn:jboss:module:1.1" name="org.eclipse.persistence">
<resources>
<resource-root path="jipijapa-eclipselink-1.0.1.Final.jar"/>
<resource-root path="eclipselink.jar"/>
</resources>
<dependencies>
...
</dependencies>
</module>
workaround for issueid=414974
$ bin/jboss-cli.sh —connect
[standalone@localhost:9990 /] /system-property=eclipselink.archive.factory:add(value=org.jipijapa.eclipselink.JBossArchiveFactoryImpl)
mysql-connector-java-5.1.30-bin.jar in /usr/local/wildfly-8.1.0.Final/modules/system/layers/base/com/mysql/main
corresponding module.xml
<?xml version="1.0" encoding="UTF-8"?>
<module xmlns="urn:jboss:module:1.1" name="com.mysql">
<resources>
<resource-root path="mysql-connector-java-5.1.30-bin.jar"/>
</resources>
<dependencies>
<module name="javax.api"/>
<module name="javax.transaction.api"/>
</dependencies>
</module>
$ bin/jboss-cli.sh --connect
[standalone@localhost:9990 /] /subsystem=datasources/jdbc-driver=mysql:add(driver-name=mysql,driver-module-name=com.mysql,driver-class-name=com.mysql.jdbc.Driver)
[standalone@localhost:9990 /] /subsystem=datasources/data-source=vaadin_sandbox:add(driver-name=mysql, user-name=secret, password=secret, connection-url=jdbc:mysql://localhost:3306/vaadin_sandbox?zeroDateTimeBehavior=convertToNull&useUnicode=true&characterEncoding=UTF-8, min-pool-size=5, max-pool-size=15, jndi-name=java:/jdbc/innodron, enabled=true, validate-on-match=true, valid-connection-checker-class-name=org.jboss.jca.adapters.jdbc.extensions.mysql.MySQLValidConnectionChecker, exception-sorter-class-name=org.jboss.jca.adapters.jdbc.extensions.mysql.MySQLExceptionSorter)
最佳答案
修订:在这个问题上花费几个小时后记录我的发现
常见:Wildfly 8.1.0.Final、MySQL 5.6.20、Vaadin 7.3.5、EclipseLink 2.5.2、javax.persistence 2.1.0、mysql-connector-java 5.1.34
情况1)persistence.xml transaction-type="RESOURCE_LOCAL",shared_cache_mode="NONE"
在这种情况下,清除 EntityManagerFactory 缓存似乎是解决问题的唯一方法。
public void refreshTable2() {
//Evict Entity Manager Cache for the specific item
em.getEntityManagerFactory().getCache().evict(Price.class, 3);
// if container is not refreshed, tbl_prices is not updated in the UI.
pricesContainer.refresh();
// popup message to display the values read from the containers
String msg = "Product container Qty= " +
String.valueOf(productsContainer.getItem(2).getEntity().getQty()) + "\n" +
"Price container Qty= " +
String.valueOf(pricesContainer.getItem(3).getEntity().getProduct().getQty()) + "\n" +
pricesContainer.getContainerProperty(3, "product.qty");
Notification.show("Test", msg, Notification.Type.ERROR_MESSAGE);
}
案例2)persistence.xml transaction-type="RESOURCE_LOCAL",shared_cache_mode="ALL"
在这种情况下,不需要逐出EntityManagerFactory缓存,但pricesContainer需要手动刷新嵌套属性来刷新其值。
public void refreshTable2() {
// if container is not refreshed, tbl_prices is not updated in the UI.
pricesContainer.refresh();
}
情况 3) persistence.xml transaction-type="JTA"、shared_cache_mode="ALL"或 "NONE"。(查看 this blog entry 了解如何使 Vaadin 与 JTA 事务配合使用)
对于这两种情况,都不需要逐出 EntityManagerFactory 缓存,但pricesContainer 需要手动刷新嵌套属性来刷新其值。上面的是shared_cache_mode可以设置为“NONE”,这似乎是Vaadin JPAContainer发挥良好作用所必需的(根据Vaadin论坛中的几个建议)
public void refreshTable2() {
// if container is not refreshed, tbl_prices is not updated in the UI.
pricesContainer.refresh();
}
欢迎就如何在无需手动干预的情况下刷新嵌套属性提供任何建议。在实际项目中,手动刷新将需要为源容器使用一个 Container.addItemSetChangeListener(),为容器中的每个项目使用一个 Container.getItem(i).addValueChangeListener() - 这会产生巨大的开销。
关于mysql - 无法刷新 Vaadin JPAContainer 嵌套属性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27220091/
所以我试图设置“内容”类的高度,但它似乎不起作用。我对嵌套 DIV 非常陌生,我已经尝试了我在谷歌搜索中发现的修复程序,但似乎没有任何效果。帮助?
好的,所以我一直在四处寻找,但找不到这个问题的答案。但是,我需要将一个 View 嵌套在另一个 View 中。 我有一个 $layout 正在使用我拥有的 default.layout Blade 文
好的,所以我一直在四处寻找,但找不到这个问题的答案。但是,我需要将一个 View 嵌套在另一个 View 中。 我有一个 $layout 正在使用我拥有的 default.layout Blade 文
基本上,我的问题很简单,但它需要知道 Struts 1.1 并且还活着的人。 我尝试构建的伪代码看起来像这样: IF element.method1 = true THEN IF element
我正在尝试将 Excel 嵌套 IF 语句转换为代码语言,但我不确定我是否正确执行此操作,希望能得到一些帮助 这是Excel语句: =IF(D3="Feather",IF(OR(I3>1000,R3=
如果我们创建两个或三个评论并对其进行多次回复,则“有用”链接在单击时会导致问题,它会对具有相同编号的索引执行 ng-click 操作,从而显示具有相同索引的所有文本。如何解决此嵌套问题,以便在单击链接
我在项目中使用Scala,想与Stripe集成,但它只提供Java API。例如,要创建 session ,我使用: val params = new util.HashMap[String, Any
以下代码有一个 Div,其中连续包含四个较小的 Div。四个 Div 中的每一个还包含一个较小的 Div,但此 Div 未显示。我尝试了各种显示和位置组合,看看 div 是否会出现。 classGoa
我在这里有一个问题,循环是: for (i=0; i < n; ++i) for (j = 3; j < n; ++j) { ...
我正在尝试编写代码来显示具有奇数宽度的形状。形状完成后,将其放置在外部形状内。用户将能够输入用于形状的字符和行数。我希望生成一个形状,并通过 for 循环生成一个外部形状。 ***** .
$(".globalTabs").each(function(){ var $globalTabs = $(this); var parent = $globalTabs.parent
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 9 年前。 Improve th
所以我在这个问题上遇到了一些麻烦,因为变量 i。我只是不确定在第二个 while 循环中如何处理它。对于我的外循环,我知道它将运行 log_4(n^2) 次迭代。对于内部 while 循环,我计算的迭
我似乎找不到在枚举上应用多个 if/then 逻辑的工作方式。 anyOf 不应用条件逻辑,而是表示如果其中任何一个匹配则很好。 allOf 再次不应用条件逻辑,而是测试属性/必填字段的超集。 这是一
如何访问 ReaderT 的内部 monad。 在我的例子中,我有类型: newtype VCSSetupAction a = VCSSetupAction (ReaderT (Maybe VCSCo
这个问题在这里已经有了答案: Add leading zeroes/0's to existing Excel values to certain length (7 个回答) 7年前关闭。 我正在寻
我已经绑定(bind)了很多 AND/OR 函数的组合并且没有运气。 这是我需要创建的: 在 B 列中,我有公司 ID,范围从两个数字字符到六个数字字符。 我需要在 B 列中的每个公司 ID 之前的每
我是 VBA 新手,在尝试编写的宏中使用 If 语句时遇到了一些困难。每个月我都会收到一份 Excel 报告,其中列出了我们公司的哪些员工执行了某些任务。我正在编写的宏旨在将每个员工的数据复制并粘贴到
如果在 B 列中找到单元格 A1 中的值,则使用文本 321 填充除非在 C 列中找到单元格 A1 中的值,在这种情况下填充文本 121反而。如果单元格 A1 的内容不在 B 列或 C 列中,则使用
我有几十万个地址。其中一些在整数之后有粒子。如 4356 A Horse Avenue , 其他格式正常4358 Horse Avenue .有些有“A”,有些有“B”。我正在尝试删除整数和粒子之间的
我是一名优秀的程序员,十分优秀!