1

我正在尝试做一些 NativeQueries,但我坚持使用 @SqlResultSetMapping 配置。

我有这些课程:

@Entity  
public class LocalUser implements Serializable {  
    private static final long serialVersionUID = 1265845L;  
    @Id  
    private String username;  
    @Column(nullable=false)  
    private String password;  

    @OneToMany  
    private List<RoleName> roles;  

    public LocalUser() {  
    }  

    public LocalUser(String username, String password, List<RoleName> roles) {  
        this.username = username;  
        this.password = password;  
        this.roles = roles;  
    }      

    public String getPassword() {  
        return password;  
    }  

    public void setPassword(String password) {  
        this.password = password;  
    }  

    public List<RoleName> getRoles() {  
        return roles;  
    }  

    public void setRoles(List<RoleName> roles) {  
        this.roles = roles;  
    }  

    public String getUsername() {  
        return username;  
    }  

    public void setUsername(String username) {  
        this.username = username;  
    }  
}  

@Entity  
public class RoleName implements Serializable {  
    private static final long serialVersionUID = 12598741564894L;  
    @Id  
    @GeneratedValue(strategy = GenerationType.IDENTITY)  
    private Long id;  

    private String roleName;  

    public RoleName() {  
    }  

    public RoleName(Long id, String roleName) {  
        this.id = id;  
        this.roleName = roleName;  
    }  

    public RoleName(String roleName) {  
        this.roleName = roleName;  
    }  

    public Long getId() {  
        return id;  
    }  

    public void setId(Long id) {  
        this.id = id;  
    }  

    public String getRoleName() {  
        return roleName;  
    }  

    public void setRoleName(String roleName) {  
        this.roleName = roleName;  
    }  
}

我的问题是,如何为类 LocalUser 编写propper @SqlResultSetMapping。我的测试 SQL 语句是:

select 'user' as username, 'passwd' as password, 1 as id, 'admin' as roleName;  

我想获得一个实体本地用户,用户名用户、密码 passwd 和角色列表,其中 id 为 1 的管理员。

我认为是这样的:

@SqlResultSetMapping(name="LocalUserMapping",  
    entities={  
        @EntityResult(entityClass=LocalUser.class,fields={  
            @FieldResult(name="username",column="username"),  
            @FieldResult(name="password",column="password")  
        }),  
        @EntityResult(entityClass=RoleName.class,fields={  
            @FieldResult(name="id",column="id"),  
            @FieldResult(name="roleName",column="roleName")  
        })  
    })

但它给了我两个对象,而不是一个。有人可以帮我吗?谢谢。

4

1 回答 1

0

这两个对象是使用entityClass=注释产生的(2x,一个用于 LocalUser,一个用于 RoleName)。将它们组合成一个 entityClass 定义,将返回一个对象。

于 2013-03-13T16:22:23.540 回答