HTTP状态500-请求处理失败;嵌套异常是org.springframework.dao.dataIntegrityViolationException:键“groups_groupid”的重复条目“2”;SQL[N/A];约束[null];嵌套异常是org.hibernate.exception.constraintViolationException:键“groups_groupid”的重复项“2”
以下是相关的类
group.java:
package com.youthministry.domain;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.Id;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
@Entity(name="GROUP_DETAILS")
public class Group {
@Id
@GeneratedValue(strategy=GenerationType.AUTO)
private Long groupId;
@Column(name = "GROUP_NAME", unique = true, nullable = false)
private String groupName;
private String groupDesc;
/*public String getIdAsString() {
return new Long(groupId).toString();
}*/
public Long getGroupId() {
return groupId;
}
public void setGroupId(Long groupId) {
this.groupId = groupId;
}
public String getGroupName() {
return groupName;
}
public void setGroupName(String groupName) {
this.groupName = groupName;
}
public String getGroupDesc() {
return groupDesc;
}
public void setGroupDesc(String groupDesc) {
this.groupDesc = groupDesc;
}
}
package com.youthministry.domain;
import java.util.ArrayList;
import java.util.Collection;
import javax.persistence.CascadeType;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Inheritance;
import javax.persistence.InheritanceType;
import javax.persistence.OneToMany;
@Entity
@Inheritance (strategy=InheritanceType.JOINED)
public class PageContent {
@Id
@GeneratedValue(strategy=GenerationType.AUTO)
private Long pageContentId;
@Column(name="PAGE_CONTENT_NAME", nullable=false)
private String pageContentName;
@Column(name="LOCATION", nullable=false)
private String location;
@OneToMany(cascade=CascadeType.REMOVE)
private Collection<Group> groups = new ArrayList<Group>();
public Long getPageContentId() {
return pageContentId;
}
public void setPageContentId(Long pageContentId) {
this.pageContentId = pageContentId;
}
public String getPageContentName() {
return pageContentName;
}
public void setPageContentName(String pageContentName) {
this.pageContentName = pageContentName;
}
public String getLocation() {
return location;
}
public void setLocation(String location) {
this.location = location;
}
public Collection<Group> getGroups() {
return groups;
}
public void setGroups(Collection<Group> groups) {
this.groups = groups;
}
}
package com.youthministry.domain;
import javax.persistence.Entity;
@Entity
public class Image extends PageContent {
private String pathToImage;
private String altText;
private String titleText;
public String getPathToImage() {
return pathToImage;
}
public void setPathToImage(String pathToImage) {
this.pathToImage = pathToImage;
}
public String getAltText() {
return altText;
}
public void setAltText(String altText) {
this.altText = altText;
}
public String getTitleText() {
return titleText;
}
public void setTitleText(String titleText) {
this.titleText = titleText;
}
}
package com.youthministry.domain;
import javax.persistence.Entity;
import javax.persistence.Lob;
@Entity
public class TextEntry extends PageContent {
private String contentTitle;
@Lob
private String contentBody;
public String getContentTitle() {
return contentTitle;
}
public void setContentTitle(String contentTitle) {
this.contentTitle = contentTitle;
}
public String getContentBody() {
return contentBody;
}
public void setContentBody(String contentBody) {
this.contentBody = contentBody;
}
}
任何帮助都很感激,提前感谢。
以下是所有相关db表的create table脚本:
CREATE TABLE `PageContent_GROUP_DETAILS` (
`PageContent_pageContentId` bigint(20) NOT NULL,
`groups_groupId` bigint(20) NOT NULL,
UNIQUE KEY `groups_groupId` (`groups_groupId`),
KEY `FK43215F8D912C9AF9` (`PageContent_pageContentId`),
KEY `FK43215F8D11E7050D` (`groups_groupId`),
CONSTRAINT `FK43215F8D11E7050D` FOREIGN KEY (`groups_groupId`) REFERENCES `GROUP_DETAILS` (`groupId`),
CONSTRAINT `FK43215F8D912C9AF9` FOREIGN KEY (`PageContent_pageContentId`) REFERENCES `PageContent` (`pageContentId`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1
CREATE TABLE `Image` (
`altText` varchar(255) DEFAULT NULL,
`pathToImage` varchar(255) DEFAULT NULL,
`titleText` varchar(255) DEFAULT NULL,
`pageContentId` bigint(20) NOT NULL,
PRIMARY KEY (`pageContentId`),
KEY `FK437B93B4AAD3F6E` (`pageContentId`),
CONSTRAINT `FK437B93B4AAD3F6E` FOREIGN KEY (`pageContentId`) REFERENCES `PageContent` (`pageContentId`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1
CREATE TABLE `PageContent` (
`pageContentId` bigint(20) NOT NULL AUTO_INCREMENT,
`LOCATION` varchar(255) NOT NULL,
`PAGE_CONTENT_NAME` varchar(255) NOT NULL,
PRIMARY KEY (`pageContentId`)
) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=latin1
CREATE TABLE `GROUP_DETAILS` (
`groupId` bigint(20) NOT NULL AUTO_INCREMENT,
`groupDesc` varchar(255) DEFAULT NULL,
`GROUP_NAME` varchar(255) NOT NULL,
PRIMARY KEY (`groupId`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=latin1
您正在使groups_groupid
唯一。
但是PageContent
类中的关系是OneTomany
。
在关系表将如下所示。
PageContentID GroupID
1 2
1 1
1 3
2 1
2 3
UNIQUE KEY `groups_groupId` (`groups_groupId`),
CREATE TABLE `PageContent_GROUP_DETAILS` (
`PageContent_pageContentId` bigint(20) NOT NULL,
`groups_groupId` bigint(20) NOT NULL,
UNIQUE KEY `groups_groupId` (`groups_groupId`),
KEY `FK43215F8D912C9AF9` (`PageContent_pageContentId`),
KEY `FK43215F8D11E7050D` (`groups_groupId`),
CONSTRAINT `FK43215F8D11E7050D` FOREIGN KEY (`groups_groupId`) REFERENCES `GROUP_DETAILS` (`groupId`),
CONSTRAINT `FK43215F8D912C9AF9` FOREIGN KEY (`PageContent_pageContentId`)
REFERENCES `PageContent` (`pageContentId`))
ENGINE=InnoDB DEFAULT CHARSET=latin1
我正在尝试编写一段代码来索引搜索一个值,如果它存在于数组中。以下是代码的样子: 每次我运行代码时,在将值输入数组时,它都会给我这个空指针异常:线程“main”java中的异常。lang.NullPointerException:无法存储到int数组,因为在indexSearch处“[]”为null。main(indexSearch.java:22) 为什么会这样,我该如何修复它?
问题内容: 谁能解释这种行为?运行: 导致没有输出,而: 产生预期的输出: 管道不应该一步一步地执行第二个示例中对test.file的重定向吗?我对破折号和bash壳都尝试了相同的代码,并且两者的行为相同。 问题答案: 该选项最近添加了一个选项,当停用作业控制时,该选项允许管道中的最后一条命令在当前外壳程序中运行,而不是子外壳程序中运行。 确实会输出
我有一个示例程序,用于为航空公司注册人员。 在Registration类的selectSeats方法中,我有一个try-catch块,其中catch语句应该捕获InputMissMatchException,以防用户输入非数值。 但是,重新输入操作没有发生,因此,当发生异常时,程序只是抛出错误消息并继续到末尾(这会导致意外结果) 这就是有问题的方法 编辑:我通过使方法在catch块中递归来解决这个
问题内容: 我有一个带有唯一主键列的表。有时,当我执行查询时会收到错误消息,因为该值已被使用。 我可以使用和捕获此特定错误吗? 问题答案: 看起来mysql为重复的主键抛出了1062错误代码。您可以检查sql异常的错误代码: 注意,这种方法不是跨数据库供应商的,因为不同的供应商对于重复的PK可能具有不同的错误代码。
我正在使用JSF1.2和PrimeFaces3.5开发一个示例应用程序。我在桌面上有RAD并创建了一个新的动态web项目。我已经用primeface编辑器标记编写了xhtml文件。但是,当我管理这个项目的时候..它为FacesServlet抛出“java.lang.ClassNotFoundException”,尽管该servlet存在于类路径中。 我已经在我的类路径中添加了下面的jar.. my