Hibernate如何实现从一张表查询插入到另一张表

wwwzrccom 2010-01-13 11:23:12
如两张表A(aid varchar(20) primary key,aName varcahr(20))
B(bid primary key auto_increment,aid,bname)
怎么从A查询出来插入到B表
不是用那个Hql :insert into....select
...全文
199 6 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
I am 花生 2010-01-13
  • 打赏
  • 举报
回复
如果不用HQL,那就在代码中实现吧
islandrabbit 2010-01-13
  • 打赏
  • 举报
回复
楼主这个映射是从B到A的单向关系,可以试试下面的代码:

A a = em.find(A.class, xxxx);

B b = new B();

b.setAid(a);

em.persist(b);
wwwzrccom 2010-01-13
  • 打赏
  • 举报
回复

@Id
@GeneratedValue(generator = "paymentableGenerator")
@GenericGenerator(name = "paymentableGenerator", strategy = "assigned")
@Column(name="impId")
这个改一下,是 @Column(name="aid")

wwwzrccom 2010-01-13
  • 打赏
  • 举报
回复

package com.zrc.blog.model;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;

import org.hibernate.annotations.GenericGenerator;

@Entity
public class A {

private String aid;

private String aName;

@Id
@GeneratedValue(generator = "paymentableGenerator")
@GenericGenerator(name = "paymentableGenerator", strategy = "assigned")
@Column(name="impId")
public String getAid() {
return aid;
}

public void setAid(String aid) {
this.aid = aid;
}

public String getaName() {
return aName;
}

public void setaName(String aName) {
this.aName = aName;
}
}
package com.zrc.blog.model;

import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.ManyToOne;

@Entity
public class B {

private int bid;

private String bname;

private A aid;

@ManyToOne
@JoinColumn(name = "aid",nullable = false)
public A getAid() {
return aid;
}

public void setAid(A aid) {
this.aid = aid;
}

@Id
@GeneratedValue
public int getBid() {
return bid;
}

public void setBid(int bid) {
this.bid = bid;
}

public String getBname() {
return bname;
}

public void setBname(String bname) {
this.bname = bname;
}

}

  • 打赏
  • 举报
回复
entity帖出来~
wwwzrccom 2010-01-13
  • 打赏
  • 举报
回复
我用HQL的时候总是插入不进去产,总是说没有映射,我用的是Annotation注解,但是可以在数据库脚本执行!不知道为什么??

67,549

社区成员

发帖
与我相关
我的任务
社区描述
J2EE只是Java企业应用。我们需要一个跨J2SE/WEB/EJB的微容器,保护我们的业务核心组件(中间件),以延续它的生命力,而不是依赖J2SE/J2EE版本。
社区管理员
  • Java EE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧