Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Column Index out of range error while executing select having two fields with same name in mapped superclass and inheriting class #2307

Closed
MarekChr opened this issue Nov 21, 2024 · 4 comments
Assignees

Comments

@MarekChr
Copy link

Stack trace
stack_trace.txt

To Reproduce

  1. Create @MappedSuperclass
  2. Create @Entity, which inherits from MappedSuperclass created earlier
  3. In MappedSuperclass, add field, eg. @Column protected Boolean alive;
  4. In Entity, add field with same name and type, eg. @Column private boolean alive;
  5. Create named query ("select all" and add where clause, which include field created earlier) and execute it (getResultList()). You can see specific example in stack trace.

(I do not know how EclipseLink handle fields internally, so I am not sure if different access modifiers or wrapped primitive type change something, In steps to reproduce I chosed the same while encountering this bug.)

EclipseLink version
3.0.4

Java/JDK version openjdk version
"1.8.0_412"
OpenJDK Runtime Environment (Temurin)(build 1.8.0_412-b08)
OpenJDK 64-Bit Server VM (Temurin)(build 25.412-b08, mixed mode)

DB used (which is probably unrelated)
MySQL 8.4

Additional info
Parameter bounding seems OK (1 parameter expected, 1 parameter provided), however it looks like it has problem with same fields in inheriting and inherited classes while trying to map them to ?: Column Index out of range, 2 > 1 (see stack trace).

This is a design bug. Solution is to remove same field from inheriting class, however Index out of range error message seems related to something else.

@Tomas-Kraus
Copy link
Member

Tomas-Kraus commented Jan 7, 2025

I'm trying to reproduce this issue with latest EclipseLink (5.0.0-B05) and it seems to work fine.
Example is here: https://github.com/Tomas-Kraus/eclipselink-bug/tree/bug-2307

Will try 3.x branch soon, but my example needs some update, because 3.x is not JPA 3.2 compliant and I need to implement some trick to initialize persistence context without persistence.xml because of Docker ports mapping.

@Tomas-Kraus
Copy link
Member

Tomas-Kraus commented Jan 7, 2025

@Tomas-Kraus
Copy link
Member

And finally tested with 3.x: https://github.com/Tomas-Kraus/eclipselink-bug/tree/bug-2307-3.x

@Tomas-Kraus
Copy link
Member

Tomas-Kraus commented Jan 7, 2025

I was unable to reproduce this issue in EclipseLink 3.x, 4.x and master branches. Tested both boolean and Boolean in @MappedSuperclass.

Sample application reqire Docker, you can try it just by executing

    git clone https://github.com/Tomas-Kraus/eclipselink-bug.git
    git checkout bug-2307-3.x
    mvn clean verify

@Tomas-Kraus Tomas-Kraus self-assigned this Jan 7, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants