从JPA嵌入式表

时间:2016-11-12 01:10:45

标签: java spring jpa

我使用JPA运行Spring MVC应用程序来实现持久性。我有一个有更新按钮的表单。单击此按钮时,它应该更新数据库中的用户记录。 User表中包含一个嵌入式表地址。我可以访问User表中的所有字段,但不能访问嵌入表。这是我的请求映射

@RequestMapping(value="/user/{userid}",method=RequestMethod.POST)
public String Update(@ModelAttribute("user")User user,@PathVariable("userid") String userid,Model model){

这是我的User.java

@Entity
@Table(name="User")
public class User {
    @Id
    @Column(name = "userid")
    private String id;
    @Column(name="firstname")
    private String firstname;
    @Column(name="lastname")
    private String lastname;
    @Column(name="title")
    private String title;
    @Embedded
    private Address address;
    @ManyToMany
    @JoinTable(name="phone_user", joinColumns={@JoinColumn(name="userid")},
    inverseJoinColumns={@JoinColumn(name="phoneid")})
    private List<Phone> phones;

    public String getId() {
        return id;
    }
    public void setId(String id) {
        this.id = id;
    }

    public String getFirstname() {
        return firstname;
    }
    public void setFirstname(String firstname) {
        this.firstname = firstname;
    }

    public String getLastname() {
        return lastname;
    }
    public void setLastname(String lastname) {
        this.lastname = lastname;
    }
    public String getTitle() {
        return title;
    }
    public void setTitle(String title) {
        this.title = title;
    }

    public Address getAddress() {
        return address;
    }
    public void setAddress(Address address) {
        this.address = address;
    }

    public List<Phone> getPhones() {
        return phones;
    }
    public void setPhones(List<Phone> phones) {
        this.phones = phones;
    }

} 请注意地址字段的@Embedded标记。 这是我的Address.java

@Embeddable
public class Address {
    String street;
    String city;
    String state;
    String zip; 
    @Column(name="street")
    public String getStreet() {
        return street;
    }
    public void setStreet(String street) {
        this.street = street;
    }
    @Column(name="city")
    public String getCity() {
        return city;
    }
    public void setCity(String city) {
        this.city = city;
    }
    @Column(name="state")
    public String getState() {
        return state;
    }
    public void setState(String state) {
        this.state = state;
    }
    @Column(name="zip")
    public String getZip() {
        return zip;
    }
    public void setZip(String zip) {
        this.zip = zip;
    }


}

这是我发送表单数据的JSP

<html>
<head>
    <title>Home</title>

</head>
<body>
<h1>
    Hello world!  
</h1>



<form method="POST" action="/cmpe275/user/${userid}">
<table>
<tr>
    <td>Name</td>
    <td><input type="text" readonly="readonly" name="userid" value="${id}"/></td>
</tr>
<tr><tr><tr><tr><tr><tr><tr><tr><tr>
    <td>First Name</td>
    <td><input type="text"  name="firstname" value="${firstname}"/></td>
    <td>Last Name</td>
    <td><input type="text"  name="lastname" value="${lastname}"/></td>
    </tr>
    <tr>
    <tr><tr><tr><tr>
    <td>Street</td>
    <td><input type="text"  name="street" value="${street}"/></td>
    <td>City</td>
    <td><input type="text"  name="city" value="${city}"/></td>
    <td>State</td>
    <td><input type="text"  name="state" value="${state}"/></td>
    <td>Zip</td>
    <td><input type="text"  name="zip" value="${zip}"/></td>
    </tr>
    <tr><tr><tr><tr>
    <td><input type="submit" onclick="updateUser();" name="Update" value="Update"/></td>

    <td><input type="button" name="Delete" value="Delete"/></td>



</table>
</form>
</body>
<script>
function updateUser(){
    console.log("hi");
}

</script>
</html>

我无法使用getter / setter访问地址字段。 例如 - 在我的处理程序映射中 - 要获取更新的配置文件的名字,我可以使用以下命令访问它:

user.getFirstName()

但是,如果我想访问更新的地址我做了

user.getAddress.getCity()

我得到一个空值。 知道为什么吗?

1 个答案:

答案 0 :(得分:1)

我想这个

<td><input type="text"  name="street" value="${street}"/></td>
<td>City</td>
<td><input type="text"  name="city" value="${city}"/></td>
<td>State</td>
<td><input type="text"  name="state" value="${state}"/></td>
<td>Zip</td>
<td><input type="text"  name="zip" value="${zip}"/></td>

应该是

<td><input type="text"  name="address.street" value="${address.street}"/></td>
<td>City</td>
<td><input type="text"  name="address.city" value="${address.city}"/></td>
<td>State</td>
<td><input type="text"  name="address.state" value="${address.state}"/></td>
<td>Zip</td>
<td><input type="text"  name="address.zip" value="${address.zip}"/></td>

Spring控制器期望@ModelAttribute@RequestBody的结构类似于POJO。因此,如果您不使用表单并发送此数据与某些js,它看起来像

{ 
  'firstname':'peter',
  'lastname': 'griffen',
  'address': {
      'street':'31 Spooner Street'        
   }
} 

你所拥有的是完全平坦的物体。如果在User类中添加正确的setter,这可能会有效。