我对My SQL数据库有一个查询,我使用Spring Boot将其返回为Json格式。 我的问题是它只返回没有键的值,例如:
[
[
"kermit",
6
]
]
我希望它返回:
[
[
"name":"kermit",
"count" :6
]
]
我尝试将Jackson注释jar文件添加到项目中,并在我的实体模型类中使用@JsonProperty:
@Entity
@Table(name = "act_id_membership", schema = "activiti", catalog = "")
@IdClass(ActIdMembershipEntityPK.class)
public class ActIdMembershipEntity {
@JsonProperty("name")
private String userId;
@JsonProperty("group")
private String groupId;
@Id
@Column(name = "USER_ID_")
public String getUserId() {
return userId;
}
public void setUserId(String userId) {
this.userId = userId;
}
@Id
@Column(name = "GROUP_ID_")
public String getGroupId() {
return groupId;
}
public void setGroupId(String groupId) {
this.groupId = groupId;
}
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
ActIdMembershipEntity that = (ActIdMembershipEntity) o;
return Objects.equals(userId, that.userId) &&
Objects.equals(groupId, that.groupId);
}
@Override
public int hashCode() {
return Objects.hash(userId, groupId);
}
}
但是它仍然没有密钥返回。我现在该怎么办?请帮我! 非常感谢你!
答案 0 :(得分:1)
首先,我同意那些评论无效的JSON格式的人。您可以在此处查看示例https://json.org/example.html
第二,您需要创建一个对象JSON,其中包含所需的字段,例如:
public class UserStat es implements Serializable {
private String name;
private long count;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public long getCount() {
return count;
}
public void setCount(long count) {
this.count = count;
}
}
并在您的自定义查询中。根据这种方式,您的报酬看起来像:
@Query("SELECT u.name, count(u) FROM User u")
public List<UserStat> findUserStat() ;