您好以下实体;hql内部连接预计加入的路径!错误
@Entity
public class FilesInfo {
@Id
@GeneratedValue
private Integer id;
private String name;
private String url;
@OneToMany(cascade= CascadeType.ALL)
@JoinColumn(name="fileId")
private Collection<FilesShare> filesShared = new ArrayList<FilesShare>();
public Collection<FilesShare> getFilesShared() {
return filesShared;
}
public void setFilesShared(Collection<FilesShare> filesShared) {
this.filesShared = filesShared;
}
//getters & setters
}
另一个
@Entity
public class FilesShare {
private Integer id;
private int userId;
private int owner;
}
的resultand表是:
mysql> desc filesshare;
+--------+---------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+--------+---------+------+-----+---------+----------------+
| id | int(11) | NO | PRI | NULL | auto_increment |
| userId | int(11) | NO | | NULL | |
| owner | int(11) | NO | | NULL | |
| fileId | int(11) | YES | MUL | NULL | |
+--------+---------+------+-----+---------+----------------+
4 rows in set (0.01 sec)
mysql> desc filesinfo;
+-------+--------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+-------+--------------+------+-----+---------+----------------+
| id | int(11) | NO | PRI | NULL | auto_increment |
| name | varchar(255) | YES | | NULL | |
| url | varchar(255) | YES | | NULL | |
+-------+--------------+------+-----+---------+----------------+
3 rows in set (0.00 sec)
我想使HQL为我做了下面的SQL:
select a.id, a.name, a.url from FilesInfo a inner join FilesShare b
on a.id=b.fileid where b.userid=5 and b.owner=1;
那给出以下输出:
mysql> select a.id, a.name, a.url from FilesInfo a inner join FilesShare b on a.
id=b.fileid where b.userid=5 and b.owner=1;
+----+-------------------+-------------------------------------+
| id | name | url |
+----+-------------------+-------------------------------------+
| 1 | dwnld_btn_1.png | C:\shareapp\admin\dwnld_btn_1.png |
| 2 | dwnld_btn_1.png | C:\shareapp\admin\dwnld_btn_1.png |
| 3 | dwnld_btn_1.png | C:\shareapp\admin\dwnld_btn_1.png |
| 4 | dwnld_btn_1_1.png | C:\shareapp\admin\dwnld_btn_1_1.png |
+----+-------------------+-------------------------------------+
我尝试以下HQL:
select a.id, a.name, a.url from FilesInfo a inner join FilesShare b
where a.id=b.fileid and b.userid=5 and b.owner=1
,但我得到这个错误
路径预期的加入! [select a.id,a.name,a.url from app.domain.FilesInfo a join join FilesShare b where a.id = b.fileid and b.userid = 5 and b.owner = 1]
怎么办内现在加入,是个问题
三江源
fileid是来自filesinfo表的id列,它是一个外键。我认为它明确从entityclasses我的意思是以上给出 – Aadam 2013-04-27 08:11:06