0

我有两张桌子:

 CREATE TABLE [LeTYPE](
    [LeNAME] [varchar](100) NOT NULL,
    [Le_DESC] [varchar](500) NULL,
    [LeFOR] [varchar](50) NOT NULL,
 CONSTRAINT [PK_LeTYPE] PRIMARY KEY CLUSTERED 
(
    [LeNAME] ASC
)
)

CREATE TABLE [Le](
    [SN] [int] IDENTITY(1,1) NOT NULL,
    [LeNAME_FK] [varchar](100) NOT NULL,
    [Le_SN] [int] NULL,
    [LOWERRANGE] [float] NOT NULL,
    [UPPERRANGE] [float] NOT NULL,
    [Le_DESC] [varchar](500) NULL,
    [COLOR] [varchar](45) NULL,
 CONSTRAINT [Le_pk] PRIMARY KEY CLUSTERED 
(
    [SN] ASC
))
GO


ALTER TABLE [Le]  WITH CHECK ADD  CONSTRAINT [FK_Le_LeTYPE] FOREIGN KEY([LeNAME_FK])
REFERENCES [LeTYPE] ([LeNAME])
ON UPDATE CASCADE
ON DELETE CASCADE
GO

ALTER TABLE [Le] CHECK CONSTRAINT [FK_Le_LeTYPE]
GO

LETYPE 中的一个元组将有多个 LE。

netbeans 生成的 JPA 实体:

     public class Letype implements Serializable {
    private static final long serialVersionUID = 1L;
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    @Basic(optional = false)
    @NotNull
    @Size(min = 1, max = 100)
    @Column(nullable = false, length = 100)
    private String Lename;
    @Size(max = 500)
    @Column(name = "Le_DESC", length = 500)
    private String LeDesc;
    @Basic(optional = false)
    @NotNull
    @Size(min = 1, max = 50)
    @Column(nullable = false, length = 50)
    private String Lefor;
    @OneToMany(cascade = CascadeType.ALL, mappedBy = "LenameFk", fetch = FetchType.LAZY)
    private List<Le> LeList;
}



public class Le implements Serializable {

    private static final long serialVersionUID = 1L;
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    @Basic(optional = false)
    @NotNull
    @Column(nullable = false)
    private Integer sn;
    @Column(name = "Le_SN")
    private Integer LeSn;
    @Basic(optional = false)
    @NotNull
    @Column(nullable = false)
    private double lowerrange;
    @Basic(optional = false)
    @NotNull
    @Column(nullable = false)
    private double upperrange;
    @Size(max = 500)
    @Column(name = "Le_DESC", length = 500)
    private String LeDesc;
    @Size(max = 45)
    @Column(length = 45)
    private String color;
    @JoinColumn(name = "LeNAME_FK", referencedColumnName = "LeNAME", nullable = false)
    @ManyToOne(optional = false, fetch = FetchType.LAZY)
    private Letype LenameFk;
}

现在,我想要的是,如果我从 JSF 视图添加一个 LETYPE,我想同时添加多个 LE。

LETYPE 
      -LE1
      -LE2
      -LE3

netbean 生成的实体结构letypeList与中乐而不是相反。我的数据库结构是错误的还是如何做对?

4

2 回答 2

2

是的,我觉得你在数据库中的LE和之间的关系有误LETYPE

从 JPA 的角度来看,当前关系被视为一个 LE可以有很多 LETYPE,这就是为什么您在LE实体类中看到下面的代码。

     @OneToMany(mappedBy = "LeFk")
     private List<Letype> letypeList; 

但这是错误的,你需要反向关系,即一个 LETYPE可以有很多 LE(一对多)。

我猜你基本上database structure是错的,你必须在表中维护FK列,LE目前你在LETYPE.

在数据库世界中,FK列始终位于Many side 中,在您的情况下,即LE表。

现在要做什么

  • LETYPE删除表中的 FK 列
  • LE在表中添加引用LETYPE表主键的 FK 列
  • 再次生成 JPA 实体
  • 然后你会看到正确的 JPA 代码和正确的关系。

我希望那时你应该能够做你需要的。

于 2013-11-08T10:36:12.793 回答
1

“我想要的是,如果我从 JSF 视图添加一个 LETYPE,我想同时添加多个 LE” 意味着 LETYPE 可以看作是组件类,而 LE 是复合类,所以你应该反转映射注释。为了说明这一点以及@Jayasagar 的详细解释,这两个类的形式如下所示:

Letype.java:

public class Letype implements Serializable {
    ...
    @OneToMany(mappedBy="letype")
    private List<Le> les;
}

勒爪哇:

public class Le implements Serializable {
    ...
    @ManyToOne
    @JoinColumn(name = "Letype_FK", referencedColumnName = "LENAME")
    private Letype letype;
}
于 2013-11-08T10:45:10.830 回答