里面下面的原生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(){  ...
Java5 引入了一种主要用于数组的增强型 for 循环,类似js中的for inpublic class Member { public static void main(String[]&...
java stringBuffer(1).stringBuffer和stringBuilder区别stringBuffer是线程安全的,stringBuilder速度更快(2).简单的stringBuffer例子StringBuffer sBuffer = new&nb...
pattern表示正则表达式,接收正则表达式作为参数例子:String content = "my name is gaojiufeng"; String pattern = "....
java匹配一个字符串在另外一个字符串中出现的次数,java正则start,java正则end// 正则 String pattern = "\\bgao\\b"; // 字符串 String content ...