Hibernate的查询是怎么实现的?
使用session.get(Class,Object)方法的时候能直接取出一个对象,只要简单地进行类型转换就行了,这是怎么做到的啊?可不可以详细解释一下,最好有代码。不要...
使用session.get(Class,Object)方法的时候能直接取出一个对象,只要简单地进行类型转换就行了,这是怎么做到的啊?可不可以详细解释一下,最好有代码。不要叫我去看Hibernate的源码,那会头晕的
展开
4个回答
2013-08-19
展开全部
简单地说,Hibernate在查询出一行数据之后,内部实现还是将数据读出到ResultSet里,然后分析session.get(Class, Object)函数的Class参数,通过类反射可以知道该Class包含哪些对象并且newInstance一个该类的对象,然后从ResultSet读出属性填充到该对象。用户只需要对这个对象进行简单的类型转换就可以使用了。
代码也有,是之前写一个持久化类库的时候写的。
static final ActiveRecord setupObject (Object object, ResultSet resultSet) throws java.sql.SQLException, ObjectAnalysisException
{
Map<Field, Accesstor> fields = ActiveRecord.analizeObjectFields(object);
try
{
for(Field field : fields.keySet())
{
Object value = resultSet.getObject(field.getName());
if(value != null)
fields.get(field).getSetter().invoke(object, value);
}
}
catch(SQLException err)
{
throw err;
}
catch(Exception err)
{
if(err instanceof IllegalAccessException || err instanceof IllegalArgumentException)
throw new ObjectAnalysisException(err.toString(), err);
else if(err instanceof InvocationTargetException)
throw new ObjectAnalysisException(err.toString(), err);
}
object.setId(resultSet.getLong("id"));
return object;
}
这段代码你无法编译因为还依赖其他的一些类,但是看看这个流程就大致能知道Hibernate如何智能地产生一个对象了。
代码也有,是之前写一个持久化类库的时候写的。
static final ActiveRecord setupObject (Object object, ResultSet resultSet) throws java.sql.SQLException, ObjectAnalysisException
{
Map<Field, Accesstor> fields = ActiveRecord.analizeObjectFields(object);
try
{
for(Field field : fields.keySet())
{
Object value = resultSet.getObject(field.getName());
if(value != null)
fields.get(field).getSetter().invoke(object, value);
}
}
catch(SQLException err)
{
throw err;
}
catch(Exception err)
{
if(err instanceof IllegalAccessException || err instanceof IllegalArgumentException)
throw new ObjectAnalysisException(err.toString(), err);
else if(err instanceof InvocationTargetException)
throw new ObjectAnalysisException(err.toString(), err);
}
object.setId(resultSet.getLong("id"));
return object;
}
这段代码你无法编译因为还依赖其他的一些类,但是看看这个流程就大致能知道Hibernate如何智能地产生一个对象了。
迈杰
2024-11-30 广告
2024-11-30 广告
迈杰转化医学研究(苏州)有限公司于2013年成立,其前身为凯杰(苏州)转化医学研究有限公司。基于基因组学、蛋白组学、细胞组学及病理组学等综合性转化医学平台,丰富的伴随诊断开发经验,高质量的管理体系以及高素质的研发管理团队,迈杰转化医学为全球...
点击进入详情页
本回答由迈杰提供
2013-08-19
展开全部
以下关于楼主的问题是我个人对Hibernate的认识
//====
对于表 Com
建表脚本
CREATE TABLE [dbo].[JC_Coms] (
[id] [bigint](19, 0) NOT NULL ,
[num] [varchar] (10) COLLATE Chinese_PRC_CI_AS NOT NULL ,
[name] [varchar] (255) COLLATE Chinese_PRC_CI_AS NOT NULL ,
[tel1] [varchar] (100) COLLATE Chinese_PRC_CI_AS NULL,
[tel2] [varchar] (100) COLLATE Chinese_PRC_CI_AS NULL,
)
Hibernate需要一个Pojo类和hbm.xml文件与之对应
1.Pojo类
public class Com implements java.io.Serializable {
private Long id;
private String num;
private String name;
private String tel1;
private String tel2;
//get set 方法省略
}
2.XML文件
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
<class name="Com" table="Coms" >
<id name="id" type="java.lang.Long">
<column name="id" />
<generator class="assigned" />
</id>
<property name="num" type="string">
<column name="num" length="10" not-null="true" />
</property>
<property name="name" type="string">
<column name="name" length="255" not-null="true" />
</property>
<property name="tel1" type="string">
<column name="tel1" length="100" />
</property>
<property name="tel2" type="string">
<column name="tel2" length="100" />
</property>
</class>
</hibernate-mapping>
通过以上两部,Hibernate就建立了数据表和Java类的关联(这里简单介绍下, 最好是看专业的文档和教程)
//====
当你调用 session.get(Class,Object) 这个方法的时候
Hibernate 会根据 Xml配置文件的内容知道你要去找的是那个数据库,该数据库的主键是什么,需要返回的的字段是什么
比如我们这个例子, 它就知道是 [Coms] 数据库, 主键是[ID], 需要的字段是全部在xml配置过的
于是,他就生成了这样一条Sql
select id,name,num,tel1,tel2 from Com where id = 你输入的主键的值
通过这条SQL结合JDBC他就得到了记录集(java.sql.ResultSet)
java.sql.ResultSet rs = ...
现在说一下 Hibernate 从记录集到Pojo类的转化,这里用到了Java的反射
先根据java.lang.class.newInstance()得到一个Com对象
Class comClass = Class.forName("Com");
Object com = comClass.newInstance();
然后是根据xml配置文件调用set方法放值, 比如我们现在放ID
//这里的"id"是根据 id节点的name属性, 如 <id name="id" type="java.lang.Long">
java.beans.PropertyDescriptor pd = new java.beans.PropertyDescriptor("id", comClass);
java.lang.reflect.Method writeMethod = pd.getWriteMethod();
//这里的"id"是根据 id节点下的column节点的name属性, 如 <id><column name="id" /></id>
writeMethod.invoke(com, rs.get("id"))
其他的字段同理
然后就把 com 对象给你返回了
//====
对于表 Com
建表脚本
CREATE TABLE [dbo].[JC_Coms] (
[id] [bigint](19, 0) NOT NULL ,
[num] [varchar] (10) COLLATE Chinese_PRC_CI_AS NOT NULL ,
[name] [varchar] (255) COLLATE Chinese_PRC_CI_AS NOT NULL ,
[tel1] [varchar] (100) COLLATE Chinese_PRC_CI_AS NULL,
[tel2] [varchar] (100) COLLATE Chinese_PRC_CI_AS NULL,
)
Hibernate需要一个Pojo类和hbm.xml文件与之对应
1.Pojo类
public class Com implements java.io.Serializable {
private Long id;
private String num;
private String name;
private String tel1;
private String tel2;
//get set 方法省略
}
2.XML文件
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
<class name="Com" table="Coms" >
<id name="id" type="java.lang.Long">
<column name="id" />
<generator class="assigned" />
</id>
<property name="num" type="string">
<column name="num" length="10" not-null="true" />
</property>
<property name="name" type="string">
<column name="name" length="255" not-null="true" />
</property>
<property name="tel1" type="string">
<column name="tel1" length="100" />
</property>
<property name="tel2" type="string">
<column name="tel2" length="100" />
</property>
</class>
</hibernate-mapping>
通过以上两部,Hibernate就建立了数据表和Java类的关联(这里简单介绍下, 最好是看专业的文档和教程)
//====
当你调用 session.get(Class,Object) 这个方法的时候
Hibernate 会根据 Xml配置文件的内容知道你要去找的是那个数据库,该数据库的主键是什么,需要返回的的字段是什么
比如我们这个例子, 它就知道是 [Coms] 数据库, 主键是[ID], 需要的字段是全部在xml配置过的
于是,他就生成了这样一条Sql
select id,name,num,tel1,tel2 from Com where id = 你输入的主键的值
通过这条SQL结合JDBC他就得到了记录集(java.sql.ResultSet)
java.sql.ResultSet rs = ...
现在说一下 Hibernate 从记录集到Pojo类的转化,这里用到了Java的反射
先根据java.lang.class.newInstance()得到一个Com对象
Class comClass = Class.forName("Com");
Object com = comClass.newInstance();
然后是根据xml配置文件调用set方法放值, 比如我们现在放ID
//这里的"id"是根据 id节点的name属性, 如 <id name="id" type="java.lang.Long">
java.beans.PropertyDescriptor pd = new java.beans.PropertyDescriptor("id", comClass);
java.lang.reflect.Method writeMethod = pd.getWriteMethod();
//这里的"id"是根据 id节点下的column节点的name属性, 如 <id><column name="id" /></id>
writeMethod.invoke(com, rs.get("id"))
其他的字段同理
然后就把 com 对象给你返回了
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
2013-08-19
展开全部
通常是hibernate.cfg.xml中对数据库连接进行了描述,而对于每一个数据库表都有一个pojo类描述和xml描述,比如数据库中有user表,则对应有User.java这个pojo类和User.hbm.xml描述。当session.get(Class,Object)的时候,Hibernate框架会通过上面说的配置文件获取要获取的对象内部细节,并生成sql语句提交给数据库,根据数据库返回的数据再封装成你要的对象。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
2013-08-19
展开全部
根据 id节点下的column节点的name属性, 如 <id><column name="id" /></id>
writeMethod.invoke(com, rs.get("id"))
根据数据库返回的数据再封装成你要的对象。
writeMethod.invoke(com, rs.get("id"))
根据数据库返回的数据再封装成你要的对象。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询