hibernate 命名查询问题!

如:1、Queryq=session.creatQuery("fromuserwhereusername="+username+"");2、Queryq=session.... 如:
1、Query q = session.creatQuery("from user where username="+username+"");
2、Query q = session.creatQuery("from user where username=:username");
q.setString("username",username);
3\Query q = session.creatQuery("from user where username=?");
q.setString(0,username);
上面3种查询方式,那种效率高! 有没有更好的!
展开
 我来答
LHLBT3GOOD
2010-02-08 · TA获得超过546个赞
知道小有建树答主
回答量:401
采纳率:0%
帮助的人:537万
展开全部
效率?

都一样!

都是HQL查询.

你的第一种和后两者的差别是安全性,防止sql注入

除了HQL查询,还可以用方法查询啊~

save(); delete()什么的;
如果是条件查询,可以用Decriterion表达式,
然后配合Expression的 eq and 等方法

Expression.eq("username",username)判断相对与否

最后用.list();就可以的到记录
大雅新科技有限公司
2024-11-19 广告
这方面更多更全面的信息其实可以找下大雅新。深圳市大雅新科技有限公司从事KVM延长器,DVI延长器,USB延长器,键盘鼠标延长器,双绞线视频传输器,VGA视频双绞线传输器,VGA延长器,VGA视频延长器,DVI KVM 切换器等,优质供应商,... 点击进入详情页
本回答由大雅新科技有限公司提供
zhou376335336
2010-02-07
知道答主
回答量:51
采纳率:0%
帮助的人:13万
展开全部
我个人觉得第3种方法好一些。
第一种方法别人可以注入式攻击的,
第二种没用过,看起来跟第3种差不多,不过第3种写起来更简便一些
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式