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

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

高老师1年前 (2024-05-21)JAVA243

里面下面的原生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限制1个方法同一时间只能被一个线程访问

java限制1个方法同一时间只能被一个线程访问

java限制1个方法同一时间只能被一个线程访问public synchronized void setOrderPay(){ }加上synchronized 修饰符即可...

java String 类 ,java 字符串类,java创建字符串,java获取字符串长度,java连接字符串,java格式化字符串

java String 类 ,java 字符串类,java创建字符串,java获取字符串长度,java连接字符串,java格式化字符串

在java中字符串属于对象,刚开始我就疑惑为什么int char等类型都是小写,结果String是大写,java太反人类,后来才知道String是对象。(1).java创建字符串String text = "net"; String tex...

java数组,java创建数组,java创建数组并赋值,java数组元素个数,java foreach 循环数组,java数组排序

java数组,java创建数组,java创建数组并赋值,java数组元素个数,java foreach 循环数组,java数组排序

(1).创建数组double[] myList = new double[size];  //推荐创建方式 double myList[] = new double[size];  ...

java睡眠方法,java睡眠函数,java睡眠时间,java睡眠一分钟,java睡眠五秒钟

java睡眠方法,java睡眠函数,java睡眠时间,java睡眠一分钟,java睡眠五秒钟

(1).java睡眠函数Thread.sleep(时间);  //单位为毫秒(2).java睡眠函数例子Date dNow = new Date(); SimpleDateFormat ft = new&nbs...