Wrong type detection for sql type char(x) columns
Description
Attachments
is duplicated by
relates to
Activity
data:image/s3,"s3://crabby-images/218a2/218a23e153e99403e86fc960f3b5aa255ee5a59c" alt=""
Brett Meyer March 7, 2014 at 10:09 PM
Bulk closing tickets resolved in released versions
data:image/s3,"s3://crabby-images/a0cef/a0cef73d83e79f423b0456e754c542781975a889" alt=""
Strong Liu October 13, 2011 at 12:07 PM
data:image/s3,"s3://crabby-images/465bc/465bc6d775410c64c284e0df125b89abe9f9e217" alt=""
Ufuk Cemen August 17, 2010 at 10:27 PM
Tried Bart Vanhaute's work around :
"I have found the following workaround for native queries:
instead of
select val from table
do
select cast(val as char) from table"
it didn't work but :
" select cast(val as varchar) from table "
works fine , because the issue already hibernate assumes the value is a char not a string.
data:image/s3,"s3://crabby-images/1b86a/1b86a2e1e46fd6da92bac03122ff1c0cdd53defd" alt=""
KrashanK March 4, 2010 at 5:15 PM
Hi
It still doesn't work correctly (without patch) on jboss-5.1.0.GA with Hibernate 3.3.1.GA.
Native queries on temporary tables called from manager.createNativeQuery returns single Character instead String
data:image/s3,"s3://crabby-images/8aeb6/8aeb632c877a915be0096766ff2b82a001a190ea" alt=""
Julien Kronegg August 7, 2009 at 3:23 PM
A cleaner workaround is to define a new Dialect:
public class DialectHhh2304 extends DB2390Dialect {
public DialectHhh2304() {
super();
// workaround for http://opensource.atlassian.com/projects/hibernate/browse/HHH-2304
registerHibernateType( Types.CHAR,1, Hibernate.CHARACTER.getName() );
registerHibernateType( Types.CHAR,255, Hibernate.STRING.getName() );
}
}
Then to use instead of the original dialect (e.g. in the persistence.xml file).
I think defining a new dialect is safer than using "char(xxx as char)" (I did not test it BTW).
When executing a sql query which returns columns of sql type char, a java.lang.Character is returned. This leads to returning just the first character of the value. In my eyes a String should be returned when the char type has a width > 1. I wasn't able to determine whether this is a jdbc driver issue or a hibernate issue. When using sql type char for columns of entities no such problems occur.
Test case is attached.