<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    posts - 325,  comments - 25,  trackbacks - 0
    在平時開發中Hibernate提供的hql基本能夠滿足我們的日常需求。但是在有些特殊的情況下,還是需要使用原生的sql,并且希望sql查詢出來的結果能夠綁定到pojo上。hibernate API中的createSQLQuery 和createQuery接口。
    就像在這次的項目中,因為表結構要變化,有個新的需求:
    要從一個表中查詢極個別的字段并且還有幾個是求多條數據的和的,之前一直在使用hibernate的API,使用的都是映射過得對象。
    原對象及表結構是這樣的:
    @Entity @Table(name="T_BILL_ACCT_ITEM") @NamedQuery(name="TBillAcctItem.findAll", query="SELECT t FROM TBillAcctItem t") public class TBillAcctItem implements Serializable { 	private static final long serialVersionUID = 1L; 	@Id 	@Column(name="ACCT_ITEM_ID") 	private long acctItemId; 	 	@Column(name="ACCT_ID") 	private long acctId; 	 	@Column(name="BILLING_CYCLE_ID") 	private String billingCycleId; 	 	@Column(name="PRODUCT_ID") 	private String productId; 	 	@Column(name="SERVICE_ID") 	private String serviceId; 	 	@Column(name="ACCT_ITEM_CODE") 	private String acctItemCode; 	 	@Column(name="ORIGINAL_AMOUNT") 	private int originalAmount; 	 	@Column(name="CDR_DISCOUNT") 	private int cdrDiscount; 	 	@Column(name="ACCT_DISCOUNT") 	private int acctDiscount; 	 	@Column(name="RECE_AMOUNT") 	private int receAmount; 	 	@Column(name="REAL_AMOUNT") 	private int realAmount; 	 	@Column(name="CHARGE_OFF_SOURCE") 	private int chargeOffSource; 	 	@Column(name="STATE") 	private int state;
    但是我現在需要查詢出來的信息是這樣的一個pojo類:
    public class ProductBillInfo implements Serializable{  	private static final long serialVersionUID = 1L; 	private String productId;//產品標識 	private String serverId;//服務標示 	private int realAmount;//實收金額(sum求和) 	private int receAmount;//應收金額(sum求和) 	private int state;//賬目狀態 	private String billingCycle;//賬期(月)

    因為hibernate要查詢的對象是要和表結構一一映射的,現在求和字段這些個是映射不了的,
    之前的方法就有問題了。 找了很多看了hibernate的API 找到這個東西。 如下:
    大概的使用過程:
            StringBuffer b = new StringBuffer();   	//... 省略SQL拼接代碼   	String sql = b.toString();   	SQLQuery query = session.createSQLQuery(sql);  	query.addScalar("productId", StandardBasicTypes.STRING);//要查詢出來的字段、類型 	List<ProductBillInfo> lnfo =query.list();

    下面是我用到的查詢pojo的方法中的實現:
    @SuppressWarnings("unchecked") 	public List<ProductBillInfo> findByAcctIdAndCycle1(long acctId, 			String cycleBegin, String cycleEnd, int state){ 		 		List<String> cycles = DateUtil.getAllCycle(cycleBegin, cycleEnd); 		StringBuffer buf = new StringBuffer(); 		buf.append("select t.PRODUCT_ID as productId , t.SERVICE_ID as  serviceId ," + 		"sum(t.REAL_AMOUNT) as  realAmount  ,sum(t.RECE_AMOUNT) as  receAmount ," + 		"t.STATE as state ,t.BILLING_CYCLE_ID as  billingCycleId " + 		" from T_BILL_ACCT_ITEM t where t.STATE= '" + state + "' AND t.ACCT_ID='" + acctId + "' AND t.BILLING_CYCLE_ID in ("); 		StringBuffer bf = new StringBuffer(); 		for(String id : cycles){ 			   if(bf.toString().equals("")){ 				   bf.append("'"+id+"'"); 			   } else{ 				   bf.append(","+"'"+id+"'"); 			   } 		} 		buf.append(bf.toString()); 		buf.append(") GROUP BY t.PRODUCT_ID,t.BILLING_CYCLE_ID,t.SERVICE_ID"); 		 		SQLQuery query = getSession().createSQLQuery(buf.toString());   		query.addScalar("productId", StandardBasicTypes.STRING); 		query.addScalar("serviceId", StandardBasicTypes.STRING); 		query.addScalar("realAmount", StandardBasicTypes.INTEGER); 		query.addScalar("receAmount", StandardBasicTypes.INTEGER); 		query.addScalar("state", StandardBasicTypes.INTEGER); 		query.addScalar("billingCycleId", StandardBasicTypes.STRING); 		 		query.setResultTransformer(Transformers.aliasToBean(ProductBillInfo.class));   		List<ProductBillInfo> lnfo =query.list(); 		return lnfo; 	}
    需要說明的一點是
    query.addScalar("deviceId",Hibernate.STRING); ,老版本的使用的數據的類型都是 org.hibernate.type包下面的,
    新版本的是在:org.hibernate.type.StandardBasicTypes包下面的
    并且在語法中要使用到in(‘’、‘’、‘’)的語法,于是寫了下面的一個拼接小方法:
    public static void main(String[] args) { 		List<String> c = new ArrayList<String>(); 		c.add("1");c.add("2");c.add("3"); 		StringBuffer bf = new StringBuffer(); 		for(String id : c){ 			   if(bf.toString().equals("")){ 				   bf.append("'"+id+"'"); 			   } else{ 			       bf.append(","+"'"+id+"'"); 			   } 			} 		System.out.println(bf.toString()); 	} 
    打印結果是: '1','2','3'
    使用StringBuffer拼接到原生的sql語句中
    轉自:http://www.aichengxu.com/view/35553
    posted on 2015-08-12 09:41 長春語林科技 閱讀(815) 評論(0)  編輯  收藏 所屬分類: hibernate
    <2015年8月>
    2627282930311
    2345678
    9101112131415
    16171819202122
    23242526272829
    303112345

     

    長春語林科技歡迎您!

    常用鏈接

    留言簿(6)

    隨筆分類

    隨筆檔案

    文章分類

    文章檔案

    相冊

    收藏夾

    搜索

    •  

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 亚洲s色大片在线观看| 亚洲AV永久无码精品| 亚洲精品伦理熟女国产一区二区| 免费91最新地址永久入口 | 日韩精品福利片午夜免费观着| 久久综合亚洲色HEZYO社区 | 欧美最猛性xxxxx免费| 亚洲一卡2卡3卡4卡国产网站| 手机看黄av免费网址| 99久久婷婷国产综合亚洲| 成人毛片18女人毛片免费96| 亚洲av纯肉无码精品动漫| 国产gav成人免费播放视频| 亚洲黄片手机免费观看| 亚洲AV无码精品色午夜果冻不卡 | 亚洲成a人片在线不卡一二三区| 女人18特级一级毛片免费视频| 风间由美在线亚洲一区| 亚洲另类少妇17p| 一区二区三区无码视频免费福利| 日韩亚洲AV无码一区二区不卡 | 久久精品国产精品亚洲| 日本免费人成网ww555在线| 亚洲小说区图片区| 色视频色露露永久免费观看| 男男gay做爽爽的视频免费| 亚洲精品无码国产| 91在线品视觉盛宴免费| 亚洲国产精品18久久久久久| 中文字幕久久亚洲一区 | 亚洲国产日韩成人综合天堂| 99久久免费国产特黄| 亚洲av无码不卡久久| 亚洲av无码乱码在线观看野外| 一级有奶水毛片免费看| 亚洲乱码日产精品BD在线观看| 亚洲国产高清精品线久久| 亚洲精品在线免费看| 男女作爱免费网站| 亚洲网址在线观看| 亚洲无码日韩精品第一页|