Hibernate怎么实现带参数的查询
现在有一个Member类,数据库中有一个memberinfo表,两者已用Hibernate建立映射。现在已知Member类中的membername和password信息,...
现在有一个Member类,数据库中有一个memberinfo表,两者已用Hibernate建立映射。现在已知Member类中的membername和password信息,要用Hibernate进行数据查询,怎么用这两个参数查询到数据库中对应的一条记录,如果没查询到即查询失败又该怎么表示,求教(注意,查询语句是写在servlet中)
memberinfo表中的一条记录不止有membername和password两列属性,还包含其他未知的属性,但目前已知的只有这两个,要查出对应的一条记录 展开
memberinfo表中的一条记录不止有membername和password两列属性,还包含其他未知的属性,但目前已知的只有这两个,要查出对应的一条记录 展开
3个回答
推荐于2016-05-09 · 知道合伙人数码行家
关注
展开全部
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;
}
然后分析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;
}
ZESTRON
2024-09-04 广告
2024-09-04 广告
在Dr. O.K. Wack Chemie GmbH,我们高度重视ZESTRON的表界面分析技术。该技术通过深入研究材料表面与界面的性质,为提升产品质量与可靠性提供了有力支持。ZESTRON的表界面分析不仅涵盖了相变化、化学反应、吸附与解吸...
点击进入详情页
本回答由ZESTRON提供
展开全部
执行hql语句"select * from tablename where membername=? and password=?";
返回Query对象 query.setString(0,传入参数1);query.setString(1,传入参数2);
返回Query对象 query.setString(0,传入参数1);query.setString(1,传入参数2);
追问
已经知道了,谢谢
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
//假设Member已经在配置文件中配置了sql语句
Query query=session.getNamedQuery("Member");
QueryUser qu=new QueryUser();
qu.SetName("ss");
qu.SetPass("pass");
query.setPropertiss(qu);
List result=query.list();
Iterator it=result.iterator()
if(it.hasnext){
//有记录
}else
{
//无
}
Query query=session.getNamedQuery("Member");
QueryUser qu=new QueryUser();
qu.SetName("ss");
qu.SetPass("pass");
query.setPropertiss(qu);
List result=query.list();
Iterator it=result.iterator()
if(it.hasnext){
//有记录
}else
{
//无
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询