hql left join on应用问题
来源:互联网 发布:重生之网络电商 编辑:程序博客网 时间:2024/06/06 15:02
网摘一:
sql: select c.* from card c left join score s on s.card_id = c.id and s.invalid_date >=curdate() where s.id is null
在hibernate中要使用left join必须声明关联映射,这里的关联是one-to-many, 在Card里面建一个Set scores,然后配置好
<set name="scores" cascade="none" where="valid_date >= curdate()">
<key column="CARD_ID"/>
<one-to-many class="Score" />
</set>
唯一特殊的就在于这个where,hql里面不能写on ,所以得on里面的条件都写在where里面,where里面是写的是字段名和针对不同数据库的sql,将导致不同数据库之间的移植增加一些工作量。
hql如下:select c from Card c left join c.scores s where s.id is null
问题是:在set中配置的key不是另外表的关键字,条件也不需要用到key,又该如何用呢?目前出现的就是这个问题,哎,找不到解决办法,问题先记录下来吧。有时间再看看
网摘之二:
有2个Table:Parent、Children。
Parent结构:id(int), name(string)。主键id。
Children结构:parentid(int), type(int), name(string)。主键parentid, type。
Children.parentid和Parent.id连接
SQL可写为SELECT * FROM Parent LEFT OUTER JOIN Children ON Parent.id=Children.parentid AND Children.type=?或SELECT * FROM Parent LEFT OUTER JOIN (SELECT * FROM Children WHERE type=?) ON Parent.id=Children.parentid
<class>
....
<set name="children" inverse="true" >
<key column="parent_Id" />
<one-to-many class="Parent" />
<filter name="typefilter" />
</set>
</class>
<filter-def name="typefilter" condition="type=:type" >
<filter-param name="type" type="string" />
</filter-def>
session.enableFilter("typefilter").setParameter("type","xxxxxxxx");
List list=session.createQuery("select p from Parent p left join p.children c").list();
问题是我的DB访问层用的是 SimpleHibernateTemplate,这里的Filter就知道如何用了
对hql不是很熟,一个问题的记录而已。
- hql left join on应用问题
- hql left join on应用问题
- hql的left join问题
- HQL left join 出错
- hql left join
- hibernat(HQL)之left join
- left join on
- sql-left join on
- left join 连表时,on后多条件无效问题
- left join应用
- inner join on, left join on, right join on讲解
- inner join on, left join on, right join on
- inner join on, left join on, right join on讲解
- inner join on, left join on, right join on讲解
- inner join on, left join on, right join on
- nner join on, left join on, right join on讲解
- inner join on, left join on, right join on讲解
- SQL--inner join on, left join on, right join on
- 张小庆,在路上-目录
- 在Hibernate中使用HQL通过Join进行关联查询
- First day of android study
- linux下 Apache mysql python mod_python Django 配置安装说明,绝对可以安装上的说明
- 开始
- hql left join on应用问题
- Windows服务
- skinmagic对VC中程序窗口的换肤
- 怎么在企业管理器中得到执行一个select语句的毫秒级时间
- SQL Server2008CPU性能监控
- 怎么做好项目主管?
- 转一个不同的声音《MapReduce: 一个巨大的倒退》
- java连接SQL Server 2005提示: java.net.ConnectException: Connection refused: connect
- 我在南大的七年