- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我的应用程序使用的是 Hibernate+Sybase。执行查询时,出现以下错误
Caused by: java.sql.SQLException: The identifier that starts with 'decision_engine_timestamp16_10' is too long. Maximum length is 30.
我在该表中有一个名为 decision_engine_timestamp 的列,它小于 30。但是为什么 Hibernate 在定义的列名之后附加 16_10?甚至 decision_engine_timestamp16_10 =30。
我无法更改表列名称。我使用 TypedQuery 而不是特定查询来搜索表。错误发生在下面指定的行上:
public static final <S extends Serializable, M> PageResult<M> findByPage(EntityManager em,
WhereBuilder<S, M> whereBuilder, S searchCriteria, Class<M> modelClass, PageRequest pageRequest) {
CriteriaBuilder criteriaBuilder = em.getCriteriaBuilder();
CriteriaQuery<M> contentCriteriaQuery = criteriaBuilder.createQuery(modelClass);
Root<M> contentRoot = contentCriteriaQuery.from(modelClass);
contentCriteriaQuery.select(contentRoot);
if (searchCriteria != null) {
contentCriteriaQuery.where(whereBuilder.build(searchCriteria, criteriaBuilder, contentRoot));
if (pageRequest != null && pageRequest.getOrders() != null) {
contentCriteriaQuery.orderBy(QueryUtils.toOrders(pageRequest.getSort(), contentRoot, criteriaBuilder));
}
}
TypedQuery<M> contentQuery = em.createQuery(contentCriteriaQuery);
if (pageRequest != null) {
CriteriaQuery<Long> totalCriteriaQuery = criteriaBuilder.createQuery(Long.class);
Root<M> totalRoot = totalCriteriaQuery.from(modelClass);
totalCriteriaQuery.select(criteriaBuilder.count(totalRoot));
if (searchCriteria != null) {
totalCriteriaQuery.where(whereBuilder.build(searchCriteria, criteriaBuilder, totalRoot));
}
TypedQuery<Long> totalQuery = em.createQuery(totalCriteriaQuery);
contentQuery.setFirstResult(pageRequest.getOffset());
contentQuery.setMaxResults(pageRequest.getPageSize());
List<M> resultList = contentQuery.getResultList();//--error occurs here
if (resultList == null) {
resultList = new ArrayList<M>();
}
int total = totalQuery.getSingleResult().intValue();
return new PageResult<M>(resultList, pageRequest, total);
} else {
List<M> resultList = contentQuery.getResultList();
if (resultList == null) {
resultList = new ArrayList<M>();
}
return new PageResult<M>(resultList);
}
}
select locaterequ0_.id as id1_10_, locaterequ0_.created_by as created_by2_10_, locaterequ0_.created_on as created_on3_10_, locaterequ0_.updated_by as updated_by4_10_, locaterequ0_.updated_on as updated_on5_10_, locaterequ0_.version as version6_10_, locaterequ0_.asset_code as asset_code7_10_, locaterequ0_.asset_country as asset_country8_10_, locaterequ0_.asset_full_name as asset_full_name9_10_, locaterequ0_.ccn as ccn10_10_, locaterequ0_.client_long_name as client_long_name11_10_, locaterequ0_.client_short_name as client_short_name12_10_, locaterequ0_.comment as comment13_10_, locaterequ0_.decision_engine_comment as decision_engine_comment14_10_, locaterequ0_.decision_engine_result as decision_engine_result15_10_, locaterequ0_.decision_engine_timestamp as decision_engine_timestamp16_10_, locaterequ0_.decision_strategy as decision_strategy17_10_, locaterequ0_.fee as fee18_10_, locaterequ0_.final_decision as final_decision19_10_, locaterequ0_.final_decision_inv_type as final_decision_inv_type20_10_, locaterequ0_.final_decision_source as final_decision_source21_10_, locaterequ0_.final_decision_timestamp as final_decision_timestamp22_10_, locaterequ0_.final_decision_user as final_decision_user23_10_, locaterequ0_.locate_type as locate_type24_10_, locaterequ0_.is_long_sell_locate as is_long_sell_locate25_10_, locaterequ0_.narrative as narrative26_10_, locaterequ0_.quantity as quantity27_10_, locaterequ0_.reply_event_id as reply_event_id28_10_, locaterequ0_.reply_timestamp as reply_timestamp29_10_, locaterequ0_.reply_user as reply_user30_10_, locaterequ0_.request_event_id as request_event_id31_10_, locaterequ0_.request_group as request_group32_10_, locaterequ0_.request_quantity as request_quantity33_10_, locaterequ0_.request_ticker as request_ticker34_10_, locaterequ0_.request_ticker_desc as request_ticker_desc35_10_, locaterequ0_.request_ticker_type as request_ticker_type36_10_, locaterequ0_.request_timestamp as request_timestamp37_10_, locaterequ0_.ric as ric38_10_, locaterequ0_.security_id as security_id39_10_, locaterequ0_.sedol as sedol40_10_, locaterequ0_.source_id as source_id41_10_, locaterequ0_.source_item as source_item42_10_, locaterequ0_.source_item_key as source_item_key43_10_, locaterequ0_.source_system as source_system44_10_, locaterequ0_.ticker as ticker45_10_, locaterequ0_.used_quantity as used_quantity46_10_, locaterequ0_.valid_till_timestamp as valid_till_timestamp47_10_ from gsf_locate_request locaterequ0_ where (locaterequ0_.final_decision is null) and (locaterequ0_.request_group in (? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ?)) order by locaterequ0_.id asc
最佳答案
在 Oracle 中,任何数据库对象名称(例如表、列、别名)的长度必须为 at most 30 bytes . Sybase has the same limitation也是。
Hibernate 必须为列名使用唯一的别名,因为查询可能使用自连接,然后 SELECT 子句将选择哪一列将是不明确的。
列别名由 AliasGenerator 生成这是不可配置的,因此您需要使用较短的列名。确保列名称的长度最多为 24
个字符,因为 hibernate 将添加计数器后缀以确保唯一性(例如 35_10_
)。
关于java.sql.SQLException : The identifier that starts with 'xxxx' is too long. 最大长度为 30,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34738538/
我刚刚注意到 align-self 属性的一些值,这是我以前从未见过的。什么是start、end、self-start、self-end,它们与有什么区别>flex-start 和 flex-end?
我见过程序员使用公式 mid = start + (end - start) / 2 而不是使用更简单的公式 mid = (start + end) / 2 用于查找数组或列表中的中间元素。 为什么他
我们已经设置了一个小型 AZURE VM(由 Microsoft 提供的普通 Windows 2012 R2 镜像),其中包含一个轻量级 DEMO 应用程序,该应用程序可以与 SQLExpress 和
我在笔记本电脑上安装了Xampp 3.2.1版,之前MySQL在它上面运行得很好,但突然MySQL停止运行,而阿帕奇和其他公司都在运行。当我点击开始MySQL时,它显示这个错误我使用Windows 1
我希望我能解释清楚。 我有自动生成的代码,我希望用 CSS 覆盖它。 这是我希望覆盖的代码示例: #u1150:hover #u1153-4 p {color: red} 重要提示:此代码中的“u”将
在我的 package.json 中,我有以下脚本 block : "scripts": { "start": "react-scripts start",
https://github.com/lodash/lodash/blob/3.7.0/lodash.src.js#L2781 此代码段 start = start == null 中的 +start
上下文 我一直在阅读有关如何将 TUMBLINGWINDOW 函数与 TIMSTAMP BY 子句一起使用的文档,但似乎找不到有关如何计算包含 TUMBLING WINDOW 和 TIMESTAMP
我正在使用 Grunt 运行 Protractor 端到端测试用例。我有以下三个任务(我使用的是 windows 7 机器) webdriver-stop webdriver-start Protra
我正在创建一个简单的Java程序,它具有在窗口生成器的帮助下构建的GUI。 GUI只包含一个按钮。 单击按钮后,启动一个线程,该线程将无限次打印到随机数,直到再次单击同一按钮将其停止为止。 这是我的代
我一直在摆弄创建一个运行渲染的线程,并且我遇到了这种实现它的方法: Class Main implements Runnable { private Thread thread; private bo
我如何在 StartButton 类中编写一个 touchesBegun 命令,它在场景中调用 start() 任何实例本身? 我知道......可能是 OOP 101。但今天我远远超出了我的范围。
关闭。这个问题需要更多 focused .它目前不接受答案。 想改进这个问题?更新问题,使其仅关注一个问题 editing this post . 8年前关闭。 Improve this questi
我的目标是运行多个进程并保存它们的 ProcessName和 Id供以后使用。这是我的代码 [System.Collections.ArrayList]$startedProcesses = @()
我在 8086 汇编方面没有太多经验,我想知道如果您不写起始标签 (start:) 和该标签的结尾,程序会发生什么 (end start)(围绕执行代码的标签)? 所以我的问题是这个标签是否是执行所必
我在 8086 汇编方面没有太多经验,我想知道如果您不写起始标签 (start:) 和该标签的结尾,程序会发生什么 (end start)(围绕执行代码的标签)? 所以我的问题是这个标签是否是执行所必
我想在另一个脚本的 Start() 之前从一个脚本运行 Start()。是否可以?您可以选择脚本的执行顺序吗? 最佳答案 我不太确定 Start() 但您可以配置 Awake 的脚本执行顺序,OnEn
我有一个来自 Unity 文档页面的示例程序,其中包含 IEnumerator Start() ,如下所示,但我想知道如何才能拥有正常的 void Start() > 在同一个脚本中? 我也尝试添加v
正如标题所说,“从机启动”和“从机启动”有什么区别?当我接受DBA面试时,他问了这个问题,我搜索了google但没有找到答案,有人知道吗? 最佳答案 没有区别.. Slave start; 已弃用,现
我有几十个未记录的表,文档说未记录的表在崩溃或不正常关机后会自动截断。 基于此,我需要在数据库启动后检查一些表,看它们是否为“空”并采取一些措施。 简而言之,我需要在数据库启动后立即执行一个过程。 最
我是一名优秀的程序员,十分优秀!