Hibernate其它API

----------------siwuxie095

  

  

  

  

  

  

  

  

(一)Query

  

  

1、使用 Query 对象执行查询操作,不需要写 sql 语句,但是要写 hql 语句

  

1)hql:即 Hibernate Query Language,它是 Hibernate 提供的查询语言

  

2)hql 语句和 sql 语句很相似

  

3)hql 和 sql 语句的区别:

  

1)使用sql 语句操作的是和表中字段

  

2)使用hql 语句操作的是实体类属性

  

  

  

2、"查询所有记录"hql 语句

  

from 实体类名

  

  

  

3、实现过程

  

1)创建Query 对象

  

2)调用Query 对象的方法得到结果

  

  

  

//(1) 创建 Query 对象

//

//调用 session createQuery() 方法,

//参数是 hql 语句,返回值是 Query 类型,

//创建以接收

Query query=session.createQuery("from User");

 

//(2) 调用 Query 对象的方法得到结果

//

//调用 query list() 方法得到结果,

//返回值是 List 类型,创建以接收,并

//指定泛型为 User

List<User> list=query.list();

 

for (User user : list) {

System.out.println(user);

}

  

  

  

  

  

(二)Criteria

  

  

1、使用 Criteria 对象执行查询操作,不需要写语句,直接调用方法实现

  

  

  

2、实现过程

  

1)创建Criteria 对象

  

2)调用Criteria 对象的方法得到结果

  

  

  

//(1) 创建 Criteria 对象

//

//调用 session createCriteria() 方法,

//参数是实体类的 class,返回值是 Criteria

//类型,创建以接收

Criteria criteria=session.createCriteria(User.class);

 

//(2) 调用 Criteria 对象的方法得到结果

//

//调用 criteria list() 方法得到结果,

//返回值是 List 类型,创建以接收,并指定

//泛型为 User

List<User> list=criteria.list();

 

for (User user : list) {

System.out.println(user);

}

  

  

  

  

  

(三)SQLQuery

  

  

1、使用SQLQuery 对象执行查询操作,可以调用底层 sql 语句实现

  

  

  

2、实现过程

  

1)创建SQLQuery 对象

  

2)调用SQLQuery 对象的方法得到结果

  

  

  

//(1) 创建 SQLQuery 对象

//

//调用 session createCriteria() 方法,

//参数是 sql 语句,返回值是 SQLQuery 类型,

//创建以接收

SQLQuery sqlQuery=session.createSQLQuery("select * from t_user");

 

//(2) 调用 SQLQuery 对象的方法得到结果

//

//调用 sqlQuery list() 方法得到结果,

//返回值是 List 类型,创建以接收

//

//注意:此时返回的 List 的每部分都是一

//个数组,而不是 User 对象,所以指定泛型

// Object[]

List<Object[]> list=sqlQuery.list();

 

for (Object[] objects : list) {

//Arrays.toString() 将数组作为字符串输出

System.out.println(Arrays.toString(objects));

}

  

  

  

修改:让返回的List 中每部分都是一个 User 对象

  

  

  

SQLQuery sqlQuery=session.createSQLQuery("select * from t_user");

 

//让返回的 List 中每部分都是一个 User 对象

//

//调用 sqlQuery addEntity() 方法,参数

//是实体类的 class,设置要将数据放到哪个实

//体类的对象中

sqlQuery.addEntity(User.class);

 

List<User> list=sqlQuery.list();

 

for (User user : list) {

System.out.println(user);

}

  

  

  

  

  

  

  

  

  

  

【made by siwuxie095】

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
hibernate-jpa-2.1-api 1.0.2是一个Java持久化规范的实现库。它是基于JPA(Java Persistence API)2.1规范的Hibernate实现。Hibernate是一个流行的ORM(对象关系映射)框架,用于在Java应用程序和关系数据库之间进行数据持久化。 该版本的hibernate-jpa-2.1-api是对JPA 2.1规范的实现,并且是Hibernate团队为了确保应用程序与Java EE 7兼容性而发布的一个版本。 JPA是一种使用对象模型操作数据库的标准规范,它提供了一组API,使开发人员可以使用面向对象的方式访问和操作数据库。Hibernate作为一个JPA的实现,提供了许多附加的功能和特性,使得开发人员可以更加简化和灵活地进行数据库操作。 通过使用hibernate-jpa-2.1-api,开发人员可以使用JPA的标准API,以及Hibernate提供的独有特性,来实现应用程序的数据持久化需求。它提供了实体管理器,用于管理实体对象的生命周期,以及CRUD操作。此外,它还提供了用于查询和各种持久化注解的支持。 通常情况下,使用hibernate-jpa-2.1-api需要将其添加到项目的依赖中,并与其他必需的Hibernate库一起使用。开发人员需要熟悉JPA的基本概念和API,并且理解Hibernate特有的扩展和配置选项。 总的来说,hibernate-jpa-2.1-api 1.0.2提供了开发人员在使用JPA进行数据持久化时的基本工具和功能。它是Hibernate团队为了支持JPA 2.1规范而发布的一个版本,开发人员可以使用它来简化和灵活地操作数据库。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值