hibernate mysql 外键查询null,Spring Hibernate使用Hibernate模板在外键列中一对多插入null...

I have implemented one to many relationship (annotation) as follows:

// User Class

@Entity

@Table(name="user")

public class User {

@Id @GeneratedValue(strategy=GenerationType.IDENTITY)

@Column(name="id")

private Integer id;

@Column(name="first_name")

private String firstName;

@Column(name="last_name")

private String lastName;

@Column(name="email_id")

private String emailId;

@Column(name="password")

private String password;

@OneToMany(targetEntity=Address.class,cascade=CascadeType.ALL)

@JoinColumn(name="user_id", referencedColumnName="id")

private List

addresses;

..... setters and getters

}

// Address Class

@Entity

@Table(name="address")

public class Address {

@Id @GeneratedValue(strategy=GenerationType.IDENTITY)

@Column(name="add_id")

private Integer addId;

@Column(name="pin_code")

private String pinCode;

@Column(name="street")

private String street;

@Column(name="city")

private String city;

@Column(name="state")

private String state;

... setters and getters

}

The problem is that when I am saving User object (which also contains list of one Address object) with hibernate template, it is inserting null in foreign key column ("user_id") in address table.

It fires 2 insert statements for both the tables but it is NOT firing update statement to update foreign key column

But when I use SessionFactory it works as expected (below is the code of session factory):

SessionFactory factory = template.getSessionFactory();

Session session = factory.openSession();

Transaction transaction = session.beginTransaction();

try{

//id = (Integer) template.save(user);

id = (Integer) session.save(user);

}catch(Exception e){

System.out.println(e);

id = -1;

}

transaction.commit();

session.close();

In above case it fire 2 insert and 1 update to update foreign key column

解决方案

Please check the below mapping

User.java

@Entity

@Table(name="user")

public class User {

@Id

@GeneratedValue(strategy=GenerationType.IDENTITY)

@Column(name="id")

private Integer id;

@Fetch(value = FetchMode.SELECT)

@OneToMany(cascade = CascadeType.ALL)

@JoinColumn(name = "id")

@JsonIgnore

private List

addressList ;

//remaining fields and getter setters here

}

Address.java

@Entity

@Table(name="address")

public class Address {

@Id @GeneratedValue(strategy=GenerationType.IDENTITY)

@Column(name="add_id")

private Integer addId;

@ManyToOne

@JoinColumn(name = "id", insertable = true, updatable = true, nullable = true)

private User user;

//remaining fields and getter setters here

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值