当前位置:首页 > JAVA > 正文内容

hibernate原生sql返回结果类型问题

高老师4个月前 (05-21)JAVA131

里面下面的原生sql:

sb.append(" select ");
sb.append("     max(c.COMPANY_ID) depotParentId, ");
sb.append("     max(c.COMPANY_NAME) depotParentName, ");
sb.append("     a.SETDEPOT_ID depotId, ");
sb.append("     max(d.DEPOT_NAME) depotName, ");
sb.append("     a.BILLS_ID billsId, ");
sb.append("     to_char(a.SURE_DATE,'yyyy-mm-dd') SURE_DATE, ");// 预售收款按制单日期
sb.append("     max(a.SURE_USERNAME) sureUsername, ");
sb.append("     sum(a.BILLS_NUMS) totalNums, ");
sb.append("     sum(a.use_score) useScore, ");
sb.append("     0 useDzCoupon, ");
sb.append("     sum(a.BILLS_S_SUMS) totalSsums, ");
sb.append("     sum(a.acc_fsums) totalFsums, ");
sb.append("     sum(a.BILLS_J_SUMS) totalJsums, ");
sb.append("     case when max(a.PRESALE_STATE) = 1 then 1 when max(a.PRESALE_STATE) = 0 and max(a.BILLS_NUMS) < 0 then 2 else 3 end as billsStatus, ");   // 1.已转零售 2.预售退单 3.未转零售
sb.append("     MAX( NVL(a.BILLS_TAG,'') ) billsTag, ");
sb.append("     MAX( NVL(a.VIP_ID,'') ) vipId ");
sb.append(" from d_presale a ");
sb.append(" left join a_partner_depot d on a.SETDEPOT_ID=d.DEPOT_ID ");
sb.append(" left join a_partner_company c on d.DEPOT_PARENT_ID=c.COMPANY_ID ");
sb.append(" WHERE a.SUCCESS_SURE=1 ");

case when部分只会输出 1 2 3 ,但是通过nativeQuery.getResultList()获取到的结果对象Object只能通过BigDecimal来接收,这很震惊我需要Integer接收,我不得不进行类型转换。查阅了hibernate 类型映射终于解惑,还真是这样映射,不过对于这种类型用宽类型更好一点,你需要了再进行转换也很合理。

hibernate 类型映射文档参考:

原始类型

映射类型Java 类型ANSI SQL 类型
integerint 或 java.lang.IntegerINTEGER
longlong 或 java.lang.LongBIGINT
shortshort 或 java.lang.ShortSMALLINT
floatfloat 或 java.lang.FloatFLOAT
doubledouble 或 java.lang.DoubleDOUBLE
big_decimaljava.math.BigDecimalNUMERIC
characterjava.lang.StringCHAR(1)
stringjava.lang.StringVARCHAR
bytebyte 或 java.lang.ByteTINYINT
booleanboolean 或 java.lang.BooleanBIT
yes/noboolean 或 java.lang.BooleanCHAR(1) ('Y' or 'N')
true/falseboolean 或 java.lang.BooleanCHAR(1) ('T' or 'F')

日期和时间类型

映射类型Java 类型ANSI SQL 类型
datejava.util.Date 或 java.sql.DateDATE
timejava.util.Date 或 java.sql.TimeTIME
timestampjava.util.Date 或 java.sql.TimestampTIMESTAMP
calendarjava.util.CalendarTIMESTAMP
calendar_datejava.util.CalendarDATE

二进制和大对象类型

映射类型Java 类型ANSI SQL 类型
binarybyte[]VARBINARY (或 BLOB)
textjava.lang.StringCLOB
serializable任何实现 java.io.Serializable 的 Java 类VARBINARY (or BLOB)
clobjava.sql.ClobCLOB
blobjava.sql.BlobBLOB

JDK 相关类型

映射类型Java 类型ANSI SQL 类型
classjava.lang.ClassVARCHAR
localejava.util.LocaleVARCHAR
timezonejava.util.TimeZoneVARCHAR
currencyjava.util.CurrencyVARCHAR





扫描二维码推送至手机访问。

版权声明:本文由高久峰个人博客发布,如需转载请注明出处。

本文链接:https://blog.20230611.cn/post/766.html

分享给朋友:

“hibernate原生sql返回结果类型问题” 的相关文章

java编译编码问题,java编译执行时编码问题

java编译编码问题,java编译执行时编码问题

public class test {     public static void main(String[] args) {     &...

java一个类可以有多个构造方法

java一个类可以有多个构造方法

java一个类可以有多个构造方法,根据传参类型和个数来匹配执行哪个构造方法。public class Member {     public Member(){      ...

java final 修饰符,java通过final修饰符创建常量,,java通过final修饰符声明方法不可被修改

java final 修饰符,java通过final修饰符创建常量,,java通过final修饰符声明方法不可被修改

(1).final 修饰符通常和 static 修饰符一起使用来创建类常量。(2).父类中的 final 方法可以被子类继承,但是不能被子类重写,声明 final 方法的主要目的是防止该方法的内容被修改。public class Member {   ...

java增强型for循环

java增强型for循环

Java5 引入了一种主要用于数组的增强型 for 循环,类似js中的for inpublic class Member {     public static void main(String[]&...

java Character 类,java判断字符是否是一个字母,java判断字符是否是一个数字,java判断字符是否是一个空白,java判断字符是否是小写字母,java判断字符是否是大写字母,java转换字符为大写,java转换字符为小写

java Character 类,java判断字符是否是一个字母,java判断字符是否是一个数字,java判断字符是否是一个空白,java判断字符是否是小写字母,java判断字符是否是大写字母,java转换字符为大写,java转换字符为小写

java判断字符是否是一个字母System.out.println(Character.isLetter('a'));java判断字符是否是一个数字System.out.println(Character.isDigit('0'));java判断字符是否是一个空白Sy...

java stringBuffer,java stringBuffer反转字符串,java stringBuffer delete删除字符/移除字符,java stringBuffer在指定位置插入字符串,java stringBuffer替换指定位置的字符串,java stringBuffer获取指定索引的值

java stringBuffer,java stringBuffer反转字符串,java stringBuffer delete删除字符/移除字符,java stringBuffer在指定位置插入字符串,java stringBuffer替换指定位置的字符串,java stringBuffer获取指定索引的值

java stringBuffer(1).stringBuffer和stringBuilder区别stringBuffer是线程安全的,stringBuilder速度更快(2).简单的stringBuffer例子StringBuffer sBuffer = new&nb...