Hibernate怎么实现带参数的查询

现在有一个Member类,数据库中有一个memberinfo表,两者已用Hibernate建立映射。现在已知Member类中的membername和password信息,... 现在有一个Member类,数据库中有一个memberinfo表,两者已用Hibernate建立映射。现在已知Member类中的membername和password信息,要用Hibernate进行数据查询,怎么用这两个参数查询到数据库中对应的一条记录,如果没查询到即查询失败又该怎么表示,求教(注意,查询语句是写在servlet中)
memberinfo表中的一条记录不止有membername和password两列属性,还包含其他未知的属性,但目前已知的只有这两个,要查出对应的一条记录
展开
 我来答
day忘不掉的痛
推荐于2016-05-09 · 知道合伙人数码行家
day忘不掉的痛
知道合伙人数码行家
采纳数:62646 获赞数:223943
本人担任公司网络部总经理多年,有充足的网络经验、互联网相关知识和资讯。

向TA提问 私信TA
展开全部
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;
}
ZESTRON
2024-09-04 广告
在Dr. O.K. Wack Chemie GmbH,我们高度重视ZESTRON的表界面分析技术。该技术通过深入研究材料表面与界面的性质,为提升产品质量与可靠性提供了有力支持。ZESTRON的表界面分析不仅涵盖了相变化、化学反应、吸附与解吸... 点击进入详情页
本回答由ZESTRON提供
A354123417
推荐于2018-03-29 · TA获得超过1298个赞
知道小有建树答主
回答量:1610
采纳率:100%
帮助的人:339万
展开全部
执行hql语句"select * from tablename where membername=? and password=?";
返回Query对象 query.setString(0,传入参数1);query.setString(1,传入参数2);
追问
已经知道了,谢谢
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
全场最最佳
2012-05-19
知道答主
回答量:51
采纳率:0%
帮助的人:6.8万
展开全部
//假设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
{
//无
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式