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;
}
执行hql语句"select * from tablename where membername=? and password=?";
返回Query对象 query.setString(0,传入参数1);query.setString(1,传入参数2);
你为什么要判断query是否为空呢?你想要的不就是有没有在数据库查到对应的数据吗?那你为什么不直接判断all的大小呢,这样不是更直观嘛。
//假设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
{
//无
}
用户登录
还没有账号?立即注册
用户注册
投稿取消
文章分类: |
|
还能输入300字
上传中....