里面下面的原生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 类型 |
---|---|---|
integer | int 或 java.lang.Integer | INTEGER |
long | long 或 java.lang.Long | BIGINT |
short | short 或 java.lang.Short | SMALLINT |
float | float 或 java.lang.Float | FLOAT |
double | double 或 java.lang.Double | DOUBLE |
big_decimal | java.math.BigDecimal | NUMERIC |
character | java.lang.String | CHAR(1) |
string | java.lang.String | VARCHAR |
byte | byte 或 java.lang.Byte | TINYINT |
boolean | boolean 或 java.lang.Boolean | BIT |
yes/no | boolean 或 java.lang.Boolean | CHAR(1) ('Y' or 'N') |
true/false | boolean 或 java.lang.Boolean | CHAR(1) ('T' or 'F') |
映射类型 | Java 类型 | ANSI SQL 类型 |
---|---|---|
date | java.util.Date 或 java.sql.Date | DATE |
time | java.util.Date 或 java.sql.Time | TIME |
timestamp | java.util.Date 或 java.sql.Timestamp | TIMESTAMP |
calendar | java.util.Calendar | TIMESTAMP |
calendar_date | java.util.Calendar | DATE |
映射类型 | Java 类型 | ANSI SQL 类型 |
---|---|---|
binary | byte[] | VARBINARY (或 BLOB) |
text | java.lang.String | CLOB |
serializable | 任何实现 java.io.Serializable 的 Java 类 | VARBINARY (or BLOB) |
clob | java.sql.Clob | CLOB |
blob | java.sql.Blob | BLOB |
映射类型 | Java 类型 | ANSI SQL 类型 |
---|---|---|
class | java.lang.Class | VARCHAR |
locale | java.util.Locale | VARCHAR |
timezone | java.util.TimeZone | VARCHAR |
currency | java.util.Currency | VARCHAR |
java限制1个方法同一时间只能被一个线程访问public synchronized void setOrderPay(){ }加上synchronized 修饰符即可...
(1).final 修饰符通常和 static 修饰符一起使用来创建类常量。(2).父类中的 final 方法可以被子类继承,但是不能被子类重写,声明 final 方法的主要目的是防止该方法的内容被修改。public class Member {  ...
java判断字符是否是一个字母System.out.println(Character.isLetter('a'));java判断字符是否是一个数字System.out.println(Character.isDigit('0'));java判断字符是否是一个空白Sy...
java stringBuffer(1).stringBuffer和stringBuilder区别stringBuffer是线程安全的,stringBuilder速度更快(2).简单的stringBuffer例子StringBuffer sBuffer = new&nb...
(1).创建数组double[] myList = new double[size]; //推荐创建方式 double myList[] = new double[size];  ...
(1).java获取当前日期时间Date date = new Date(); System.out.println(date.toString());输出Fri Jul 02 10:29:55 CST 2021(2).java获取时间戳秒/毫秒D...