weixin_42393324 2011-04-13 15:48
浏览 252
已采纳

QBC查询关联表困惑

A表:User表
private Long id;
/**
* 用户名
/
private String name;
/
*
* 登陆密码
/
private String password ;
/
*
* 创建时间
*/
private String createtime;

B 表:WorkLog表

  private Long id;
/**
 * 上传用户
 */
private CUser user;
/**
 * 工作类型
 */
private String workTypeId;
/**
 * 创建时间
 */
private String createtime;

A,B两表关联,
SQL写法:

select t.* from c_worklog t where to_char(to_date(trim(t.createtime),'yyyy-mm-dd hh24:mi:ss'),'yyyy-mm-dd') = '2011-04-12' and t.userid in (select c.id from c_user c where c.name ='2377');可以执行成功

QBC写法:
public List search(Map map, int firstresult, int maxresults) {
// TODO Auto-generated method stub
List list1 = null;
try
{
Criteria criteria = this.getSession().createCriteria(CWorkLog.class);
Iterator it = map.entrySet().iterator();
while (it.hasNext())
{
Map.Entry pairs = (Map.Entry) it.next();
if(pairs.getKey().equals("createtime")){
criteria = criteria.add(
Restrictions
.sqlRestriction(
" to_char(to_date(trim(createtime),'yyyy-mm-dd hh24:mi:ss'),'yyyy-mm-dd') = ?",
pairs.getValue().toString().trim(),
Hibernate.STRING));
}else if (pairs.getKey().equals("name"))
{
criteria = criteria.createCriteria("user").add(Restrictions.eq("name", pairs.getValue()
.toString()));
}
}
list1 =criteria.setFirstResult(
(firstresult - 1) * maxresults).setMaxResults(maxresults).list();
}
catch (Exception e)
{
e.printStackTrace();
}
return list;
}

[color=red]QBC执行时候单个查询例如:进行createtime或者name查询都可以,但是两个合并查询就出错:ORA-00918: 未明确定义列[/color]

  • 写回答

1条回答 默认 最新

  • CaiHuajiang 2011-04-13 16:46
    关注

    首先ORA-00918: 未明确定义列说明了这个SQL语句有问题。

    在SQL语句中由于多表关联或子查询视图的原因导致有两个及以上的字段的名称重复。

    所以SQL语句无法确定该选择那个字段作为最终的列。。

    既然你用Hibernate,那么将最终的生成的SQL语句拿到其他工具中去查看下就明白了

    Good Luck!

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 用verilog实现tanh函数和softplus函数
  • ¥15 求京东批量付款能替代天诚
  • ¥15 slaris 系统断电后,重新开机后一直自动重启
  • ¥15 谁能帮我看看这拒稿理由啥意思啊阿啊
  • ¥15 关于vue2中methods使用call修改this指向的问题
  • ¥15 idea自动补全键位冲突
  • ¥15 请教一下写代码,代码好难
  • ¥15 iis10中如何阻止别人网站重定向到我的网站
  • ¥15 滑块验证码移动速度不一致问题
  • ¥15 Utunbu中vscode下cern root工作台中写的程序root的头文件无法包含