- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
经过大量搜索和试验,我陷入困境......我有两个类,一个是 ExpectedSecurityReturn,另一个是 ForecastReturnType。 ForecastReturnType 是 ExpectedSecurityReturn 的成员,但在持久数据时不应插入。我不断收到“权限不足”的消息,但我知道用户确实具有对表 Expected_security_return 的删除/插入权限,因为我使用 JDBC 进行了测试,并且 JPA 删除工作正常。因此,我认为这与我的类(class)有关。
@Table(name = "EXPECTED_SECURITY_RETURNS")
@Entity
@IdClass(ExpectedSecurityReturn.ExpectedSecurityReturnPK.class)
public class ExpectedSecurityReturn {
@Id
@Column(name = "REP_SEC_ID")
private Integer repSecId;
@Id
@Column(name = "AS_OF_DATE")
private Date date;
@Id
@ManyToOne(optional = false)
@JoinColumn(name = "RETURN_TYPE_ID", referencedColumnName = "RETURN_TYPE_ID", insertable=false)
private ForecastReturnType returnType;
@Column(name="CURR_TOUSD_RET") // local currency to usd
private Double currencyToUsdReturn;
}
主键类,其中包括 ForecastReturnType:
// ------------------------------
// PK
// ------------------------------
public static class ExpectedSecurityReturnPK implements Serializable {
private static final long serialVersionUID = 1325372032981567439L;
public ExpectedSecurityReturnPK() {
}
public ExpectedSecurityReturnPK(final Integer repSecId,
final Date asOfDate, ForecastReturnType returnType) {
if (repSecId == null)
throw new IllegalArgumentException("null rep sec id");
if (asOfDate == null)
throw new IllegalArgumentException("null asOfDate");
if (returnType == null)
throw new IllegalArgumentException("null returnType");
this.repSecId = repSecId;
this.date = new Date(asOfDate.getTime());
}
@Override
public boolean equals(final Object o) {
if (this == o)
return true;
if (o == null || getClass() != o.getClass())
return false;
final ExpectedSecurityReturnPK that = (ExpectedSecurityReturnPK) o;
if (repSecId != that.repSecId)
return false;
if (!date.equals(that.date))
return false;
if (!returnType.equals(that.returnType))
return false;
return true;
}
@Override
public int hashCode() {
int result = repSecId;
result = 31 * result + date.hashCode();
result = 31 * result + returnType.getForecastTypeId();
return result;
}
private int repSecId;
private Date date;
private ForecastReturnType returnType;
}
和预测返回类型:
@Table(name="EXPECTED_SEC_RET_TYPE_DECODE")
@Entity
public class ForecastReturnType {
@Id
@Column(name="RETURN_TYPE_ID")
private int forecastTypeId;
@Column(name="SHORT_NAME")
private String shortName;
@Column(name="LONG_NAME")
private String longName;
@OneToMany(fetch=FetchType.LAZY, mappedBy="returnType")
Collection<ExpectedSecurityReturn> expectedSecurityReturns;
}
谁能帮我弄清楚我做错了什么吗?我尝试了很多方法但没有成功...我认为罪魁祸首是 ExpectedSecurityReturn.returnType 因为我知道用户没有权限。
基本上,我需要插入/保留 ExpectedSecurityReturn 实例。
最佳答案
嗯,有几件事。
我强烈建议不要尝试这样做。您可能会浪费生命来解决 JPA 注释和诸如此类似乎永远无法正常工作的奇怪问题。您还会发现,当涉及到像这样的更复杂的结构时,不同的 JPA 提供程序的行为会略有不同,并且对于继承而言,它的表现会加倍。
在 EXPECTED_SECURITY_RETURNS 上创建一个唯一的 key 确实会更好,并且使用它,它会让您的 Java 生活变得更加轻松。
如果您必须做这样的事情,我对 JPA 不愿让主键组件成为另一个实体对象并不感到惊讶。虽然这在 RDBMS 中当然很有可能,但看起来像这样的小事情就会导致 JPA 出错。
我还会检查您的 JPA impl 将输出的查询日志(对于大多数 JPA 提供程序,当然是 Ecpliselink 和 Hibernate,它在持久性定义中可以相当轻松地进行配置)。我愿意打赌它正在尝试对 EXPECTED_SEC_RET_TYPE_DECODE 运行更新,如果没有,它可能会尝试获取锁(表、行或其他锁,具体取决于您的 DBMS)。如果用户无权对该表执行锁定或更新,则查询可能会因权限问题而失败,具体取决于具体的实现。
JPA 希望持有该表的锁是合理的,因为在事务期间,EXPECTED_SEC_RET_TYPE_DECODE 中引用的条目可能会发生更改,因此必须确保在更新时不会发生更改/插入到另一张 table 上。最后我检查了一下,没有办法告诉 JPA 该表本质上是静态的。如果您使用 Hibernate,您可以尝试使用 @ReadOnly 注释,但在过去,我尝试过的方法并不能解决这样的问题。
如果您确实找到了更好的解决方案,请随时发布,以便我们其他人可以学习!!
关于java - 从事务执行插入时,JPA 2.0 权限不足,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8715140/
所以我正在为考试复习,并在 SQL 河(或荒地)中撞到了一块大石头 我制作了以下表格并插入了以下数据: create table Permissions ( fileName VARCHAR(
我有一个使用 maxWidth 定义的 jqueryui 对话框。 $("#myDialog").dialog({ autoOpen: false, width: 'a
注意:我遗漏了不相关的代码 所以我目前正在研究 CCC 1996 P1,这个问题的全部目的是能够计算一个整数输入是完美数、不足数还是充数。我上面列出的代码可以工作,但是我认为它太慢了。该代码会迭代每个
已关闭。此问题需要 debugging details 。目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and the
我正在使用 Go 和 Redis 开发 API。问题是RAM使用不足,我找不到问题的根源。 TL;DR 版本 有数百/数千个哈希对象。每个 1 KB 的对象(键+值)占用大约 0.5 MB 的 RAM
在我的 GCE Kubernetes 集群上,我无法再创建 pod。 Warning FailedScheduling pod (www.caveconditions.com-f1be467e3
当我尝试在EKS Fargate群集上安装指标服务器时,它抛出错误: 0/4 nodes are available: 4 Insufficient pods. 按照以下说明从此处安装指标服务器:ht
遍布this document Apple 提到 iOS 在某些情况下会终止应用程序,最常见的原因似乎是释放一些 RAM。这会导致未实现状态恢复的应用程序出现问题——用户正在处理和暂时离开的一些内容可
尝试处理一个10分钟的音频文件时出现以下错误。我刚刚开始使用Google Cloud产品,所以我是唯一访问此资源的人。我怎么可能超出配额?配额设置为其默认值,我认为我没有任何限制。还有其他原因吗? 我
R 语言让我感到困惑。实体有模式和类,但即使这样也不足以完全描述实体。 这个answer说 In R every 'object' has a mode and a class. 所以我做了这些实验:
我在 west-1 有一个 Openshift v3 项目。在其中,我有一个运行良好的应用程序,但在 GitHub 提交代码中非常下游的内容后,该应用程序停止工作。问题在于制作 pod: No nod
我在 west-1 有一个 Openshift v3 项目。在其中,我有一个运行良好的应用程序,但在 GitHub 提交代码中非常下游的内容后,该应用程序停止工作。问题在于制作 pod: No nod
在 how-do-i-access-the-stackoverflow-api-from-mathematica我概述了如何使用 SO API 让 Mathematica 制作一些有趣的顶级回答者声誉
所以在 GKE 上,我有一个 Node.js app,每个 pod 使用大约:CPU(cores): 5m, MEMORY: 100Mi 但是我只能为每个 Node 部署 1 个 pod。我使用的是
我正在使用 async.eachOfSeries 超过 300 个数组并请求一些 GA api,它工作正常但有时我会收到错误.. UnhandledPromiseRejectionWarning:错误
我正在尝试在 AWS ec2 上托管的 kubernetes 集群上使用 mr3 设置配置单元。当我运行命令 run-hive.sh 时,Hive 服务器启动,并且 master-DAg 被初始化,但
创建订阅时有时会出现以下错误: Insufficient tokens for quota 'administrator' and limit 'CLIENT_PROJECT-100s' of ser
我是一名优秀的程序员,十分优秀!