我正在尝试做一些 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")
})
})
但它给了我两个对象,而不是一个。有人可以帮我吗?谢谢。