里面下面的原生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 |
public class test { public static void main(String[] args) { &...
java一个类可以有多个构造方法,根据传参类型和个数来匹配执行哪个构造方法。public class Member { public Member(){  ...
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中字符串属于对象,刚开始我就疑惑为什么int char等类型都是小写,结果String是大写,java太反人类,后来才知道String是对象。(1).java创建字符串String text = "net"; String tex...