0

两个实体类:

   @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;
    }

第二:

@Entity
public class FilesShare {
    @Id
    @GeneratedValue
    private Integer id;
    @Column(name="fileId")
    private Integer fileId;
    private int userId;
    private int owner;
    @ManyToOne
    @JoinColumn(name="fileId", updatable=false,insertable=false)
    private FilesInfo filesInfo;

    public FilesInfo getFilesInfo() {
        return filesInfo;
    }

    public void setFilesInfo(FilesInfo filesInfo) {
        this.filesInfo = filesInfo;
    }

daoimpl 方法:

public List<FilesInfo> reqSharedFiles(FilesShare fs) {
        session=HibernateUtil.getSessionFactory().getCurrentSession();
        session.beginTransaction();
    List<FilesInfo> filesInfo = null;
            filesInfo=(List<FilesInfo>)session.createQuery("from FilesInfo a, FilesShare b where a.id=b.fileId and b.userId=5 and b.owner=1").list();

现在我不明白hibernate何时映射并返回对象,因为我在操作中遇到了无法强制转换的错误:

Ljava.lang.Object;无法转换为 app.domain.FilesInfo

那个行动

private List<FilesInfo> furls= new ArrayList<FilesInfo>();
furls=upload.reqSharedFiles(fs);

                for(FilesInfo s: furls)  // ERROR IS SHOWING HERE
                {
                    System.out.println(s.getUrl());
                }
4

3 回答 3

3

您的查询不返回 的列表,而是返回对象类型为和FilesInfo的二元素对象数组的列表。FilesInfoFilesShare

您可以重写您的查询,使其仅返回 a FilesInfo,或附加 aResultTransformer以提取您感兴趣的部分或构造一个可用于获取您真正想要的信息的对象。

于 2013-04-27T20:29:17.947 回答
0

您的查询可能会产生两个不同的对象, from FilesInfo a, FilesShare b 因此如果它是 FileShare 对象,则不能将其转换为 FilesInfo

hql 从

于 2013-04-27T20:28:04.830 回答
0

谢谢你们。这是我经过一番搜索后所做的。

 private List<Object[]> turls=new ArrayList<Object[]>(); //get the list of Object[] from HQL


for(Object[] r : turls)
                {
                    FilesInfo inf =(FilesInfo)r[0];
                    System.out.println(inf.getUrl());
                }
于 2013-04-27T22:25:57.587 回答