- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的应用程序仅从数据库读取数据。没有创建/更新/删除操作。我正在尝试将一个数据库 View 映射到 JPA 实体。该 View 没有任何唯一的 ID。所以基本上每一行都是唯一的。但有可能某些列的值可能为空。
现在的问题是:
1) 我无法对数据库进行任何更改。这超出了我的范围。因此 View 无法添加新列作为唯一 ID。
2)我无法在没有主键的情况下创建 JPA 实体,因为它会提示它至少需要唯一的键。
3)如果我将 @Id 注释应用于所有列,那么它在逻辑上是有意义的,因为在我的情况下每一行都是唯一的。但在我的单元测试过程中,HSQLDB 会提示某些唯一列可能没有空值。
4)所以我决定推迟/禁用所有约束。因为在我的例子中,仅在使用 DBUnit 和 HsqlDb 创建内存模式时才考虑约束。
我尝试执行以下准备好的语句:
SET CONSTRAINTS ALL DEFERRED
但它失败并出现错误:
Caused by: java.sql.SQLSyntaxErrorException: user lacks privilege or object not found: CONSTRAINTS
我不确定如何在初始数据库初始化期间禁用约束检查。我已经在过去使用过禁用外键检查:
SET DATABASE REFERENTIAL INTEGRITY FALSE
并且它可以正常工作,没有任何问题。如果您对如何禁用 HsqlDb 的所有约束检查有任何想法,请告诉我。
Jar 版本:
DbUnit - 2.5.0
Junit - 4.10
HsqlDb 2.3.0
JDK - 1.7
更新1:
我将 HsqlDb jar 版本更新为 2.3.4。我找到了以下引用:
http://hsqldb.org/doc/guide/dbproperties-chapt.html#N155DE
然后我尝试最初在连接上执行这些语句:
SET DATABASE SQL UNIQUE NULLS { TRUE | FALSE }
但这并没有帮助。
更新2:
我尝试使用以下方法将这些列显式设置为 null:
ALTER TABLE T_NAME ALTER COLUMN C_NAME SET NULL
但我收到错误消息:
column is in primary key in statement [ALTER TABLE T_NAME ALTER COLUMN C_NAME SET NULL]
最佳答案
两个可能有帮助的想法:
将具有复合主键的 JPA 实体映射到现有数据库时,相对于多个 @Id 字段,@EmbeddedId 是实体的正确方法:
此外,由于它是在只读模式下使用的,因此请在 @Id 字段上使用可插入和可更新的 @Column 属性:@Column(可插入=假,可更新=假)
这些可能会导致 JPA 提供程序在唯一性问题上表现不同。
对于类似的情况,我使用 Apache Derby 删除了引用完整性约束。我认为它也适用于 HSQLDB。
您的问题没有说明您在什么时候发出删除约束命令,因此请确保在需要删除约束的每个测试开始时发出这些命令。
我编写了一个“ConstraintManipulator”类,用于删除和恢复约束。需要禁用约束的测试在测试前调用正确的 ConstraintManipulator 删除方法并在测试后添加方法(只需要为某些测试关闭特定约束并为后续测试恢复它们)。这些方法只是使用 dbUnit 配置的 JDBC 数据库连接发出 DDL 命令(“添加约束...”、“删除约束...”)。
关于java - JPA DBUnit HsqlDb : Disable constraint checks?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40175512/
我使用 jQuery 禁用选择下拉列表中的选项。我需要知道使用之间的区别 prop('disabled','disabled') 和 prop('disabled',true) 两者几乎都适用于所有浏
.attr('disabled', 'disabled') 和 .attr('disabled', true) 在我的代码中都有效,但我只是想知道:两者中哪一个更有效和/或哪一个更常用?真的有区别吗?
我的 asp.net mvc View 中有以下脚本:- function disableform(id) { $('#' + id).prop("disabled", true); } 但是
我已经在 Oracle VM Ware 中为我的 ubuntu 可信操作系统安装了 visual studio 代码和依赖项。我用这些命令运行代码。 ssh -X myserver code 但是当我
我有这个函数可以切换输入字段的禁用属性: $('.someElement').click(function(){ if (someCondition) { console.log
自从前几天我升级了 angularjs 后,我一直收到警告。每当我打开 ui.bootstrap 模式时,它都会发生。 这是我在 chrome-beta 44 中收到的警告: angular.js:1
我想限制用户在单击特定按钮时在文本框中输入值,否则设置禁用 false。如果我设置 $("#txtquery").attr("disabled","disabled"); 它将文本框设置为空白。如果切
How do I make a Spinner's "disabled" state look disabled? 可能重复. 我尝试了帖子中提到的解决方案,即 ((Spinner) spinner)
这段代码: $tds = $(this).closest('tr').find(td input,select); $tds.attr('disabled','disabled'); 使我的表格行不
使用 jQM 1.4.0我试图覆盖灰色样式(): input[type="text"]:disabled { opacity: 1.0 !important; color: black
不知道为什么这不起作用。 当人们单击我的应用程序的“编辑”按钮时,禁用的文本字段将变为可编辑: $("#bewerken").click(function(e) { $("input[d
我对以下差异有些困惑: swiftlint:disable:next swiftlint:disable:this 最佳答案 它们都用于禁用单行的快速规则。您还可以为单行启用规则。来自 SwiftLi
我看到一些代码 # pylint: disable=W0123 还有一些 # pylint: disable-msg=W0123 它们只是同义词吗? 最佳答案 从 pylint 0.21.0 开始不推
默认情况下,在桌面上,flutter 中的 btns 在禁用时会更改鼠标光标: 我们想禁用此行为,或替换为不同的光标。 最佳答案 要覆盖 ElevatedButton、TextButton 或 Out
我一直在学习很多关于标准 asp.net 验证器的知识,我的最新发现是关于如何禁用验证器客户端,这非常酷。 现在,如果我的初始帖子启用了验证器,但在客户端,我禁用它,服务器端是否识别客户端更改并保留它
默认情况下,在桌面上,flutter 中的 btns 在禁用时会更改鼠标光标: 我们想禁用此行为,或替换为不同的光标。 最佳答案 要覆盖 ElevatedButton、TextButton 或 Out
这个问题在这里已经有了答案: Should I use CSS :disabled pseudo-class or [disabled] attribute selector or is it a
我有一个 python 脚本,它发送包含文本、html 和 ics 附件的多部分电子邮件。这个想法是,现代电子邮件客户端将呈现 HTML 部分并提供将事件添加到用户日历中的功能。 代码如下: impo
我有一个最初被禁用的按钮: Lorem ipsum 对于此按钮,button.getAttribute('disabled') 返回 "disabled"。但是,当我使用 JavaScript 启用此
在我的一些测试中,我必须确认在设置某些标志时某些 select2 下拉菜单被禁用。为了证实这一点,我发现以下策略似乎有效: Assert.True(element.GetAttribute("disa
我是一名优秀的程序员,十分优秀!