一个关于Hibernate问号传值问题,请教高手。
Sessionsession=getSession();Queryquery=session.createQuery("from?asawherea.id=?");que...
Session session = getSession();
Query query = session.createQuery("from ? as a where a.id=?");
query.setParameter(0, "User");
query.setParameter(1, Admin_id);
上面代码出错:unexpected token: ? near line 1, column 6 [from ? as a where a.id=?]
如果把第一个问号换成User,小心修改下就可以正常运行了,我想把那个User对象换成个参数,以便可以一个方法访问多个数据表。高手指点迷津~~ 谢谢哟 展开
Query query = session.createQuery("from ? as a where a.id=?");
query.setParameter(0, "User");
query.setParameter(1, Admin_id);
上面代码出错:unexpected token: ? near line 1, column 6 [from ? as a where a.id=?]
如果把第一个问号换成User,小心修改下就可以正常运行了,我想把那个User对象换成个参数,以便可以一个方法访问多个数据表。高手指点迷津~~ 谢谢哟 展开
4个回答
展开全部
把那个User对象换成个参数,以便可以一个方法访问多个数据表。
弄个String tabName 作为方法参数。
然后 Query query = session.createQuery("from "+ tabName+" as a where a.id=?");
。。。才发现好多人回答了,我的采纳率啊,。,。
弄个String tabName 作为方法参数。
然后 Query query = session.createQuery("from "+ tabName+" as a where a.id=?");
。。。才发现好多人回答了,我的采纳率啊,。,。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
大哥,我知道你想写个通用的工具方法
但是你from后面是个参数
而你setParameter那里又写了个"User",这样还有什么用?
那你干脆从外面传给参数进来
String hql = "from" + entity + " where id=?";
session.createQuery(hql);
但是你from后面是个参数
而你setParameter那里又写了个"User",这样还有什么用?
那你干脆从外面传给参数进来
String hql = "from" + entity + " where id=?";
session.createQuery(hql);
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
我印象中 次处?应该只能用作替代where语句后的东西,from 后面的 表 你如果想用参数表示,可以在这段语句的方法上加入参数,然后把参数放在此处不也可以达到你要的效果吗。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
通过查询上面的判断
String tableName="";
if(XXX){
tableName="User"
}else if(XXX){
tableName="Admin"
}
String queryString="from "+tableName+ "a where a.id=?"
String tableName="";
if(XXX){
tableName="User"
}else if(XXX){
tableName="Admin"
}
String queryString="from "+tableName+ "a where a.id=?"
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询