APAR status
Closed as program error.
Error description
EclipseLink generates incorrect SQL from CriteriaBuilder for the ´CriteriaBuilder.trim(char t, Expression<String> x)´ function. It is important to note that this may not be failing as some databases will not fail attempting to execute this SQL, but the query is very wrong and cannot return the expected result. Example: ´´´ CriteriaBuilder cb = em.getCriteriaBuilder(); CriteriaQuery<Object[]> cquery = cb.createQuery(Object[].class); Root<SimpleEntity> root = cquery.from(SimpleEntity.class); cquery.multiselect(cb.trim(cb.literal('A'), cb.literal("AAHELLO WORDAAAAA"))); cquery.where(cb.equal(root.get(SimpleEntity_.strVal1), cb.literal("HELLO"))); Query query = em.createQuery(cquery).getResultList(); ´´´ Example SQL: ´´´ SELECT TRIM('AAHELLO WORDAAAAA' FROM 'AAHELLO WORDAAAAA') FROM SIMPLEENTITY WHERE (STRVAL1 = 'HELLO') ´´´
Local fix
Problem summary
**************************************************************** * USERS AFFECTED: All users of IBM WebSphere Application * * Server - Java Persistence API - JPA 2.1 & * * EclipseLink * **************************************************************** * PROBLEM DESCRIPTION: EclipseLink generates incorrect SQL * * from CriteriaBuilder * * for ´CriteriaBuilder.trim()´ functions * **************************************************************** * RECOMMENDATION: * **************************************************************** Example: ´´´ CriteriaBuilder cb = em.getCriteriaBuilder(); CriteriaQuery<Object[]> cquery = cb.createQuery(Object[].class); Root<SimpleEntity> root = cquery.from(SimpleEntity.class); cquery.multiselect(cb.trim(cb.literal('A'), cb.literal("AAHELLO WORDAAAAA"))); cquery.where(cb.equal(root.get(SimpleEntity_.strVal1), cb.literal("HELLO"))); Query query = em.createQuery(cquery).getResultList(); ´´´ Example SQL: ´´´ SELECT TRIM('AAHELLO WORDAAAAA' FROM 'AAHELLO WORDAAAAA') FROM SIMPLEENTITY WHERE (STRVAL1 = 'HELLO') ´´´
Problem conclusion
The fix for this APAR changes the EclipseLink implementation and involves an update to the third-party source. See https://bugs.eclipse.org/bugs/show_bug.cgi?id=573094 This fix is currently targeted for WebSphere Application Server 9.0.5.9. For more information, see 'Recommended Updates for WebSphere Application Server': https://www.ibm.com/support/pages/node/715553
Temporary fix
Comments
APAR Information
APAR number
PH36841
Reported component name
WEBSPHERE APP S
Reported component ID
5724J0800
Reported release
900
Status
CLOSED PER
PE
NoPE
HIPER
NoHIPER
Special Attention
NoSpecatt / Xsystem
Submitted date
2021-04-29
Closed date
2021-07-07
Last modified date
2021-07-07
APAR is sysrouted FROM one or more of the following:
APAR is sysrouted TO one or more of the following:
Fix information
Fixed component name
WEBSPHERE APP S
Fixed component ID
5724J0800
Applicable component levels
R900 PSY
UP
[{"Business Unit":{"code":"BU059","label":"IBM Software w\/o TPS"},"Product":{"code":"SSEQTP","label":"WebSphere Application Server"},"Platform":[{"code":"PF025","label":"Platform Independent"}],"Version":"9.0","Line of Business":{"code":"LOB45","label":"Automation"}}]
Document Information
Modified date:
01 November 2021