hibernate的一些用法

本文介绍了一个基于 Hibernate 的 Java 方法实现,通过 Session 回调进行数据库操作,并利用 HQL 和 Map 参数更新 AppTaskInfo 实体的数据。演示了如何创建 Query 对象并执行更新操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

<span style="white-space:pre">	</span>public Object doSessionCallback(SessionCallback sessionCallback) {
		return sessionCallback.callBack(sessionFactory.getCurrentSession());
	}
	
	public int mapExecute(final String hql, final Map<String, ?> values) {
		return createQuery(hql, values).executeUpdate();
	}
	
	public <X> List<X> find(final String hql, final Map<String, ?> values) {
		return createQuery(hql, values).list();
	}
	
	/**
	 * 根据查询HQL与参数列表创建Query对象.
	 * 与find()函数可进行更加灵活的操作.
	 * 
	 * @param values 命名参数,按名称绑定.
	 */
	public Query createQuery(final String queryString, final Map<String, ?> values) {
		Assert.hasText(queryString, "queryString不能为空");
		Query query = sessionFactory.getCurrentSession().createQuery(queryString);
		if (values != null) {
			query.setProperties(values);
		}
		return query;
	}


String hql = "update AppTaskInfo a set a.appAllTask=:appAllTask where a.id=:id";
			Map<String,Object> values = new HashMap<String, Object>();
			values.put("appAllTask", newTaskArray.toString());
			values.put("id", appTaskInfo.getId());
			subTaskService.mapExecute(hql, values);


</pre><pre code_snippet_id="495859" snippet_file_name="blog_20141024_4_2078188" name="code" class="java">



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值