- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
出于安全原因,我们的 oracle 数据库对象通常属于与登录用户不同的模式。例如。表在 xx_core 中,我们登录的用户是 xx_app_yy 。在我的 persistence.xml 中,我定义了一个 orm 文件,以便我可以在部署时指定架构名称,例如: <mapping-file>xx_schema_orm.xml</mapping-file>
然后在 xx_schema_orm.xml 中我可以定义对象拥有模式,例如:
<persistence-unit-metadata>
<persistence-unit-defaults>
<schema>xx_core</schema>
</persistence-unit-defaults>
</persistence-unit-metadata>
这对表格非常有效,但我找不到序列的等效项。它尝试使用没有模式名称的序列,然后我得到一个异常:
2010-10-14 03:04:05,423:DEBUG could not get next sequence value [select xx_SEQ.nextval from dual] - org.hibernate.util.JDBCExceptionReporterjava.sql.SQLException: ORA-02289: sequence does not exist at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:145)
I've tried to set the schema name as part of the sequence name for a generator in the xx_schema_orm.xml, but could not get it working eg.:
<sequence-generator name="xx_SEQ_GEN"
sequence-name="xx_core.xx_SEQ"/>
我可能会尝试的解决方法:
最佳答案
在 JPA 2.0 中:
@SequenceGenerator
注释和等效的 sequence-generator
元素 允许指定 schema
(和 catalog
) 名称。 schema
子元素也应该被序列生成器接受。但这不适用于 JPA 1.0。
我将只引用关于 schema
子元素的部分来说明差异(其他相关部分在下面的引用资料中提到)。来自 JPA 2.0 规范:
12.2.1.1 schema
The
schema
subelement applies to all entities, tables, secondary tables, join tables, collection tables, table generators, and sequence generators in the persistence unit.The
schema
subelement is overridden by anyschema
subelement of theentity-mappings
element; anyschema
element explicitly specified in theTable
orSecondaryTable
annotation on an entity or anyschema
attribute on anytable
orsecondary-table
subelement defined within anentity
element; anyschema
element explicitly specified in aTableGenerator
annotation ortable-generator
subelement; any schema element explicitly specified in aSequenceGenerator
annotation orsequence-generator
subelement; anyschema
element explicitly specified in aJoinTable
annotation orjoin-table
subelement; and any schema element explicitly specified in aCollectionTable
annotation orcollection-table
subelement.
来自 JPA 1.0 规范:
10.1.1.1 schema
The
schema
subelement applies to all entities, table generators, and join tables in the persistence unit.The
schema
subelement is overridden by anyschema
subelement of theentity-mappings
element; anyschema
element explicitly specified in theTable
orSecondaryTable
annotation on an entity or any schema attribute on anytable
orsecondary-table
subelement defined within anentity
element; anyschema
element explicitly specified in aTableGenerator
annotation ortable-generator
subelement; and anyschema
element explicitly specified in aJoinTable
annotation orjoin-table
subelement.
因此,除非您的提供商提供某些特定的扩展,否则我的建议是:
schema
子元素来解决问题 ~or~TableGenerator
~或~关于java - 使用 JPA 时如何在部署时设置序列的模式名称?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3937986/
我正在尝试做这样的事情:Name[i] = "Name"+ (i+1) 在 forloop 中,这样数组的值将是:Name[0] = Name1,Name[1] = Name2,Name[2] = N
我读了here,在GSP中我们可以这样写: ${params.action} 从GSP中,我们可以使用${params.action}作为参数调用Javascript函数(请参阅here)。 是否有其
我的问题:非常具体。我正在尝试想出解析以下文本的最简单方法: ^^domain=domain_value^^version=version_value^^account_type=account_ty
我创建了一条与此类似的路线: Router::connect("/backend/:controller/:action/*"); 现在我想将符合此模式的每个 Controller 路由重命名为类似
我在 Visual Studio 2013 项目中收到以下警告: SQL71502 - Procedure has an unresolved reference to object 最佳答案 这可以
任何人都可以指导我使用名称/值 .NET 集合或 .NET 名称/值字典以获得最佳性能吗?请问最好的方法是什么?我的应用程序是 ASP.NET、WCF/WF Web 应用程序。每个集合应该有 10 到
我在 Zend Framework 2 中有一个默认模块: namespace Application\Controller; use Zend\Mvc\Controller\AbstractActi
这是表格: 关于javascript - 在 javascript 中,这是一个有效的结构吗? : document. 名称.名称.值?,我们在Stack Overflow上找到一个类似的
HtmlHelper.ActionLink(htmlhelper,string linktext,string action) 如何找出正确的路线? 如果我有这个=> HtmlHelper.Actio
我需要一些有关如何将 Controller 定义传递给嵌套在 outer 指令中的 inner 指令的帮助。请参阅http://plnkr.co/edit/Om2vKdvEty9euGXJ5qan一个
请提出一个数据结构来表示内存中的记录列表。每条记录由以下部分组成: 用户名 积分 排名(基于积分)- 可选字段- 可以存储在记录中或可以动态计算 数据结构应该支持高效实现以下操作: Insert(re
错误 : 联合只能在具有兼容列类型的表上执行。 结构(层:字符串,skyward_number:字符串,skyward_points:字符串)<> 结构(skyward_number:字符串,层:字符
我想要一个包含可变数量函数的函数,但我希望在实际使用它们之前不要对它们求值。我可以使用 () => type 语法,但我更愿意使用 => type 语法,因为它似乎是为延迟评估而定制的。 当我尝试这样
我正在编写一个 elisp 函数,它将给定键永久绑定(bind)到当前主要模式的键盘映射中的给定命令。例如, (define-key python-mode-map [C-f1] 'pytho
卡在R中的错误上。 Error in names(x) <- value : 'names' attribute must be the same length as the ve
我有字符串,其中包含名称,有时在字符串中包含用户名,后跟日期时间戳: GN1RLWFH0546-2020-04-10-18-09-52-563945.txt JOHN-DOE-2020-04-10-1
有人知道为什么我会收到此错误吗?这显示将我的项目升级到新版本的Unity3d之后。 Error CS0103: The name `Array' does not exist in the curre
由于 Embarcadero 的 NNTP 服务器从昨天开始就停止响应,我想我可以在这里问:我使用非数据库感知网格,我需要循环遍历数据集以提取列数、它们的名称、数量行数以及每行中每个字段的值。 我知道
在构建Android应用程序的子项目中,我试图根据根build.gradle中的变量设置版本代码/名称。 子项目build.gradle: apply plugin: 'com.android.app
示例用例: 我有一个带有属性“myProperty”的对象,具有 getter 和 setter(自 EcmaScript 5 起支持“Property Getters 和 Setters”:http
我是一名优秀的程序员,十分优秀!