里面下面的原生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一个类可以有多个构造方法,根据传参类型和个数来匹配执行哪个构造方法。public class Member { public 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...
pattern表示正则表达式,接收正则表达式作为参数例子:String content = "my name is gaojiufeng"; String pattern = "....
java正则表达式的捕获组捕获组可以将匹配到的结果根据正则中的括号进行分组,这里变量我加了$符,php转java的坏习惯,懒得改了,能跑就行// 匹配字符串 String $line = "gaojiufeng 1994! ok?...
(4).java lookingAt匹配字符串和java matches匹配字符串lookingAt不要求整个字符串全匹配,例如me和me_you都是匹配的,但是lookingAt从第一个字符串开始匹配,匹配失败了也不会继续匹配,意味着me和you_me是无法匹配的matches匹配字符串要求全部匹...