【问题标题】:How to fetch Hibernate object and map it to JSON如何获取 Hibernate 对象并将其映射到 JSON
【发布时间】:2014-04-14 21:47:25
【问题描述】:

我有问题。当我试图获取EmployeeJSON 对象时,我看不到一个非常重要的字段(company)。例如,我需要得到这样的对象:

{
    "name": "Jack",
    "company": {
        "name": "Microsoft",
        "id": 4
    },
    "id": 1
}

但相反,我得到了一个没有公司的对象(错误!):

{
    "name": "Bill",
    "id": 2
}

同时我想获取公司的json对象:

{
    "name": "Microsoft",
    "employees": [
        {
            "name": "Jack",
            "id": 1
        },
        {
            "name": "Frank",
            "id": 3
        }
    ],
    "id": 4
}

公司对象没问题。当我得到它时,它看起来很完美。问题出在 Employee 对象中。

这是我的实体类

@Entity
@Table(name = "company")
public class Company implements Serializable {

    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    private Integer id;

    @Column
    private String name;

    @OneToMany(mappedBy = "company")
    @Cascade(value = CascadeType.ALL)
    @JsonManagedReference
    private Collection<Employee> employees;

还有我的 Employee 类

@Entity
@Table(name = "employee")
public class Employee implements Serializable {

    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    Integer id;

    @Column
    String name;

    @ManyToOne()
    @Cascade(value = org.hibernate.annotations.CascadeType.ALL)
    @JoinColumn(name = "company_id", referencedColumnName = "id")
    @JsonBackReference
    private Company company;

我认为问题在 @Json[SomeCondition] 注释中。有没有人可以帮我修复代码。我需要像这样使用 companym 获取 Employee 对象:

{
    "name": "Jack",
    "company": {
        "name": "Microsoft",
        "id": 4
    },
    "id": 1
}

更新:

这是我的控制器:

@Controller
@RequestMapping("/employee")
public class EmployeeController {

    @Autowired
    EmployeeService employeeService;

    @RequestMapping(method = {RequestMethod.GET}, produces = "application/json")
    public @ResponseBody Collection<Employee> getEmployees() {
        return employeeService.getEmployees();
    }

    @RequestMapping(value = "/{id}", method = {RequestMethod.GET, RequestMethod.PUT},
                    produces = "application/json")
    public @ResponseBody Employee getEmployee(@PathVariable("id") Integer id) {
        return employeeService.getEmployee(id);
    }

    @RequestMapping(method = RequestMethod.POST, consumes = "application/json",
                    headers = "content-type=application/json")
    public String addEmployee(@RequestBody Employee employee) {
        employeeService.addEmployee(employee);
        return "redirect:/employee";
    }

    @RequestMapping(method = RequestMethod.PUT, consumes = "application/json",
                    headers = "content-type=application/json")
    public String updateEmployee(@RequestBody Employee employee) {
        employeeService.updateEmployee(employee);
        return "redirect:/employee/" + employee.getId();
    }

    @RequestMapping(value = "/{id}", method = RequestMethod.DELETE)
    public String deleteEmployee(@PathVariable("id") Integer id) {
        employeeService.deleteEmployee(id);
        return "redirect:/employee";
    }
}

【问题讨论】:

  • 也许我误用了@JsonManagedReference 注释。
  • 请告诉我们这个问题的解决方案是什么,我也面临同样的问题

标签: java json spring hibernate jackson


【解决方案1】:

这是休眠中EAGER和LAZY取数据的问题。小心这两个概念。在实现它之前阅读它。 在 Company Class 中定义关系时添加 fetch=FetchType.EAGER。

 @OneToMany(mappedBy = "company",fetch=FetchType.EAGER)
     @Cascade(value = CascadeType.ALL)
     @JsonManagedReference
    private Collection<Employee> employees;

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2019-05-27
    • 1970-01-01
    • 2023-01-13
    • 2011-06-09
    • 1970-01-01
    • 2012-08-04
    相关资源
    最近更新 更多