Hibernate HQL ad JPQL

– Start
就如数据库提供 SQL 来查询数据库,JPA 规范提供了 JPQL (Java Persistence Query Language),Hibernate 提供了 HQL(Hibernate Query Language) 来查询数据库。其实它们的语法非常类似的。HQL 的核心接口是 org.hibernate.query.Query,通过它我们还可以直接调用 SQL 语句或存储过程。

package shangbo.hibernate.demo031;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.boot.Metadata;
import org.hibernate.boot.MetadataSources;
import org.hibernate.boot.registry.StandardServiceRegistry;
import org.hibernate.boot.registry.StandardServiceRegistryBuilder;

public class DataService implements AutoCloseable {
	private SessionFactory sessionFactory;

	public DataService() {
		// 第一步:构造 ServiceRegistry
		StandardServiceRegistry registry = new StandardServiceRegistryBuilder().configure(ClassLoader.getSystemResource("shangbo/hibernate/demo029/hibernate.cfg.xml")).build();

		// 第二步:构造 Metadata
		Metadata metadata = new MetadataSources(registry).getMetadataBuilder().applyPhysicalNamingStrategy(new MyPhysicalNamingStrategy()).build();

		// 第三步:构造 SessionFactory
		sessionFactory = metadata.buildSessionFactory();
	}

	public void beginTransaction() {
		Session session = sessionFactory.getCurrentSession();
		session.beginTransaction();
	}

	public void commit() {
		Session session = sessionFactory.getCurrentSession();
		session.getTransaction().commit();
		session.close();
	}

	// JPA Query API
	public Customer queryCustomerByName(String name) throws Exception {
		Session session = sessionFactory.getCurrentSession();
		javax.persistence.Query query = session.createQuery("from Customer where customerName = :customerName");
		query.setParameter("customerName", name);
		return (Customer) query.getSingleResult();
	}

	// Hibernate Query API
	public Customer queryCustomerByName2(String name) throws Exception {
		Session session = sessionFactory.getCurrentSession();
		org.hibernate.query.Query<Customer> query = session.createQuery("from Customer where customerName = :customerName", Customer.class);
		query.setParameter("customerName", name);
		return query.getSingleResult();
	}

	public void save(Object o) {
		Session session = sessionFactory.getCurrentSession();
		session.save(o);
	}

	@Override
	public void close() throws Exception {
		// 关闭 SessionFactory
		sessionFactory.close();
	}
}

– 更多参见:Hibernate 精萃
– 声 明:转载请注明出处
– Last Updated on 2019-07-09
– Written by ShangBo on 2019-07-09
– End

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值