`

JPA标注要注意的地方

    博客分类:
  • JPA
阅读更多

 这些标注尽量都要写到get方法的头上,我无意中把下面的标注写到了定义变量的头上时候,发生了错误。

报告错误:java.lang.NullPointerException

         怎么回事,刚刚我试了下把@Id放到getId()方法的头上结果也报上面那样的错误,然后我再把@Id又放回到private Integer id;的头上结果就没错了。这个问题要待解决下...(我个人认为都放到get的头上,但是id要放到定义的头上,这个我也不知道是什么原因)

private Set<SiteChannel> siteChannelCollection = new HashSet<SiteChannel>();

@OneToMany(cascade = CascadeType.ALL, fetch = FetchType.LAZY, mappedBy = "site")
public Set<SiteChannel> getSiteChannelCollection() {
	return siteChannelCollection;
}
public void setSiteChannelCollection(Set<SiteChannel> siteChannelCollection) {
	this.siteChannelCollection = siteChannelCollection;
}

 

private Site site;

@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "site_id")
public Site getSite() {
	return site;
}
public void setSite(Site site) {
	this.site = site;
}

 

@Id
@GeneratedValue(strategy = IDENTITY)
@Column(name = "id", unique = true, nullable = false)
public Long getId() {
	return this.id;
}
public void setId(Long id) {
	this.id = id;
}

 

@Temporal(TemporalType.TIMESTAMP)
@Column(name = "created", length = 19)
public Date getCreated() {
	return this.created;
}
public void setCreated(Date created) {
	this.created = created;
}

 

参考的例子Site.java
package cn.ctit.cms.entity;

// Generated Feb 3, 2009 4:08:09 AM by Hibernate Tools 3.2.2.GA

import java.util.Date;
import java.util.HashSet;
import java.util.Set;
import javax.persistence.CascadeType;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.GeneratedValue;
import javax.persistence.Transient;

import static javax.persistence.GenerationType.IDENTITY;
import javax.persistence.Id;
import javax.persistence.OneToMany;
import javax.persistence.Table;
import javax.persistence.Temporal;
import javax.persistence.TemporalType;

import org.hibernate.annotations.Parent;
import org.hibernate.validator.Length;
import org.hibernate.validator.Min;
import org.hibernate.validator.NotNull;
import org.hibernate.validator.Pattern;

import cn.ctit.cms.entity.pay.Biller;
import cn.ctit.cms.entity.pay.Joinoption;

/**
 * Site generated by hbm2java
 */
@Entity
@Table(name = "site", catalog = "cms")
public class Site implements java.io.Serializable {

	private Long id;
	private String name;
	private String description;
	private String siteUrl;
	private Short siteType;
	private String ioUrl;
	private String ioService;
	private Integer ioPort;
	private String ioUser;
	private String ioPass;
	private String defaultFormat;
	private Boolean enable = true;
	private Short status;
	private Date created;
	private Date modified;
	private Long serverId;
	private String template;
	private Set<SiteChannel> siteChannels = new HashSet<SiteChannel>(0);
	private Set<SiteSchedule> siteSchedules = new HashSet<SiteSchedule>(0);
	private Set<Joinoption> joinoptions = new HashSet<Joinoption>(0);
	private Set<Biller> billers = new HashSet<Biller>(0);
	//NATS
	private String nats_siteid;

	public Site() {
	}

	public Site(String name, String description, String siteUrl,
			Short siteType, String ioUrl, String ioService, Integer ioPort,
			String ioUser, String ioPass, String defaultFormat, Boolean enable,
			Short status, Date created, Date modified,
			Set<SiteChannel> siteChannels, Set<SiteSchedule> siteSchedules,Long serverId) {
		this.name = name;
		this.description = description;
		this.siteUrl = siteUrl;
		this.siteType = siteType;
		this.ioUrl = ioUrl;
		this.ioService = ioService;
		this.ioPort = ioPort;
		this.ioUser = ioUser;
		this.ioPass = ioPass;
		this.defaultFormat = defaultFormat;
		this.enable = enable;
		this.status = status;
		this.created = created;
		this.modified = modified;
		this.siteChannels = siteChannels;
		this.siteSchedules = siteSchedules;
		this.serverId = serverId;
	}

	@Id
	@GeneratedValue(strategy = IDENTITY)
	@Column(name = "id", unique = true, nullable = false)
	public Long getId() {
		return this.id;
	}

	public void setId(Long id) {
		this.id = id;
	}

	@NotNull
	@Column(name = "name", length = 100)
	@Length(max = 100)
	public String getName() {
		return this.name;
	}

	public void setName(String name) {
		this.name = name;
	}
	@Column(name = "description", length = 200)
	@Length(max = 200)
	public String getDescription() {
		return this.description;
	}

	public void setDescription(String description) {
		this.description = description;
	}
	
	@NotNull
	@Column(name = "site_url", length = 200)
	@Length(max = 200)
	public String getSiteUrl() {
		return this.siteUrl;
	}
	public void setSiteUrl(String siteUrl) {
		this.siteUrl = siteUrl;
	}
	@Column(name = "site_type")
	public Short getSiteType() {
		return this.siteType;
	}

	public void setSiteType(Short siteType) {
		this.siteType = siteType;
	}
	@NotNull
	@Column(name = "io_url", length = 200)
	@Length(max = 200)
	public String getIoUrl() {
		return this.ioUrl;
	}
	public void setIoUrl(String ioUrl) {
		this.ioUrl = ioUrl;
	}
	@Pattern(regex="[a-zA-Z]+[0-9]*",message="Please enter right value : transform!")
	@Column(name = "io_service", length = 50)
	@Length(max = 50)
	public String getIoService() {
		return this.ioService;
	}
	public void setIoService(String ioService) {
		this.ioService = ioService;
	}
	@Min(value=1)
	@Column(name = "io_port")
	public Integer getIoPort() {
		return this.ioPort;
	}
	public void setIoPort(Integer ioPort) {
		this.ioPort = ioPort;
	}
	@NotNull
	@Column(name = "io_user", length = 50)
	@Length(max = 50)
	public String getIoUser() {
		return this.ioUser;
	}

	public void setIoUser(String ioUser) {
		this.ioUser = ioUser;
	}
	@NotNull
	@Column(name = "io_pass", length = 50)
	@Length(max = 50)
	public String getIoPass() {
		return this.ioPass;
	}

	public void setIoPass(String ioPass) {
		this.ioPass = ioPass;
	}
	
	@Column(name = "default_format", length = 200)
	@Length(max = 200)
	public String getDefaultFormat() {
		return this.defaultFormat;
	}

	public void setDefaultFormat(String defaultFormat) {
		this.defaultFormat = defaultFormat;
	}
	
	@Column(name = "enable")
	public Boolean getEnable() {
		return this.enable;
	}

	public void setEnable(Boolean enable) {
		this.enable = enable;
	}
	
	@Column(name = "status")
	public Short getStatus() {
		return this.status;
	}

	public void setStatus(Short status) {
		this.status = status;
	}
	
	@Temporal(TemporalType.TIMESTAMP)
	@Column(name = "created", length = 19)
	public Date getCreated() {
		return this.created;
	}

	public void setCreated(Date created) {
		this.created = created;
	}
	
	@Temporal(TemporalType.TIMESTAMP)
	@Column(name = "modified", length = 19)
	public Date getModified() {
		return this.modified;
	}

	public void setModified(Date modified) {
		this.modified = modified;
	}

	@OneToMany(cascade = CascadeType.ALL, fetch = FetchType.LAZY, mappedBy = "site")
	public Set<SiteChannel> getSiteChannels() {
		return this.siteChannels;
	}

	public void setSiteChannels(Set<SiteChannel> siteChannels) {
		this.siteChannels = siteChannels;
	}

	@OneToMany(cascade = CascadeType.ALL, fetch = FetchType.LAZY, mappedBy = "site")
	public Set<SiteSchedule> getSiteSchedules() {
		return this.siteSchedules;
	}

	public void setSiteSchedules(Set<SiteSchedule> siteSchedules) {
		this.siteSchedules = siteSchedules;
	}

	@OneToMany(cascade = CascadeType.ALL, fetch = FetchType.LAZY, mappedBy = "site")
	public Set<Joinoption> getJoinoptions() {
		return joinoptions;
	}

	public void setJoinoptions(Set<Joinoption> joinoptions) {
		this.joinoptions = joinoptions;
	}

	@OneToMany(cascade = CascadeType.ALL, fetch = FetchType.LAZY, mappedBy = "site")
	public Set<Biller> getBillers() {
		return billers;
	}

	public void setBillers(Set<Biller> billers) {
		this.billers = billers;
	}
	
	@Column(name = "server_id")
	public Long getServerId() {
		return this.serverId;
	}

	public void setServerId(Long serverId) {
		this.serverId = serverId;
	}

	@Column(name = "nats_siteid")
	public String getNats_siteid() {
		return nats_siteid;
	}

	public void setNats_siteid(String nats_siteid) {
		this.nats_siteid = nats_siteid;
	}
	
	//@Transient
	public String getTemplate() {
		return template;
	}

	public void setTemplate(String template) {
		this.template = template;
	}

}

 

分享到:
评论

相关推荐

    JPA 标注 JPA标签手册

    例如,要将一个Java类标记为JPA实体,可以使用@Entity注解: ```java @Entity public class Employee implements Serializable { ... } ``` 您可以选择性地在实体类上添加注解以覆盖默认值,这被称为异常配置。 ...

    JPA标注推荐圈子: Database圈子

    ### JPA标注详解 #### 一、概述 Java Persistence API (JPA) 是一种用于管理关系型数据库的对象-关系映射 (ORM) 技术的标准。JPA 提供了一种简单的方法来存储和检索应用程序中的数据。通过使用注解或 XML 描述对象...

    jpa标注中文文档html格式

    **Java Persistence API (JPA)标注详解** Java Persistence API(JPA)是Java平台上的一个标准,用于管理和持久化对象关系映射(ORM)。它提供了一种方式将面向对象的模型转换为数据库中的关系数据。JPA通过使用...

    jpa 标注

    ### JPA标注详解 #### 一、概述 Java Persistence API(简称JPA)是Java企业版5(Java EE 5)中的Enterprise JavaBeans (EJB) 3.0规范的一部分,它极大地简化了EJB持久化的处理过程。JPA提供了一种对象关系映射的...

    jpa例子jpajpa

    **Java Persistence API (JPA)** 是Java平台上的一个标准,用于管理关系数据库中的对象-关系映射(ORM)。它提供了一种方式,让开发者可以用面向对象的编程模型来操作数据库,而无需直接编写SQL语句。JPA允许你在...

    jpa常用标注

    在Java Persistence API (JPA) 中,注解是用于配置实体类与数据库表之间映射的关键工具。这些注解使得开发者能够以面向对象的方式描述数据模型,而无需编写大量SQL语句。以下是一些常见的JPA注解及其用途: 1. **@...

    JPA教程JPA教程JPA教程

    Java Persistence API(JPA)是Java平台上的一个标准,用于管理关系数据库中的数据。它提供了一种面向对象的方式来处理数据库操作,使得开发人员可以使用Java类和对象来操作数据库记录,而无需直接编写SQL语句。JPA...

    JPA源文件/jpa学习

    **JPA(Java Persistence API)**是Java平台上的一个标准,用于管理关系数据库中的数据,它简化了在Java应用程序中存储、检索和管理对象的工作。JPA是Java EE和Java SE环境中的一种ORM(Object-Relational Mapping)...

    jpa 所要的jar包

    在你提到的"jpa 所要的jar包"中,可能包含了以下几个关键组件: 1. **Persistence API**:这是JPA的核心,定义了持久化操作的接口和注解,如`EntityManager`, `EntityManagerFactory`, `Entity`, `@Entity`, `@...

    Pro JPA2 精通JPA2

    《Pro JPA2:精通Java™ Persistence API》是一本由Mike Keith和Merrick Schincariol撰写的关于Java持久化API(JPA)的权威指南。本书深入探讨了JPA2,即Java Persistence API的第二版,是Java EE 6标准的一部分。...

    JPA教程,包括TOPLink JPA,Hibernate JPA,Open Jpa,jpa批注

    **Java Persistence API (JPA)** 是Java平台上的一个标准,用于管理关系数据库中的数据。它为Java开发者提供了一种对象关系映射(ORM)机制,将业务对象与数据库表进行映射,使得开发者可以使用面向对象的方式来操作...

    JPA中文解释,JPA的API

    Java Persistence API(JPA)是Java平台上的一个标准,用于管理关系数据库中的对象持久化。它简化了在Java应用程序中存储、检索和管理数据的过程,是Enterprise JavaBeans(EJB)的一部分,也是Spring框架中的一个...

    Spring Data JPA 简化 JPA 开发

    要使用 Spring Data JPA,你需要在项目环境中集成相应的库。这通常涉及到添加 Spring Data JPA、Spring Framework、JPA 实现(如 Hibernate)以及相关的依赖库。例如,Eclipse 中可以通过新建 Java 工程,并手动导入...

    jpa

    **JPA(Java Persistence API)**是Java平台上用于管理关系数据库的数据持久化标准API,它为应用程序提供了一种对象/关系映射...对于想要深入了解JPA和Java持久化技术的开发者来说,这将是一篇非常有价值的学习资源。

    JPA

    标题与描述均提到了“JPA”,这指向的是Java Persistence API(Java持久化API),一个用于Java应用中的对象-关系映射(ORM)的标准。JPA允许开发人员将数据库表映射到Java对象,从而在应用程序中以面向对象的方式...

    spring注解+spring data jpa文档+JPA文档.rar

    Spring框架的核心特性包括依赖注入(DI)和面向切面编程(AOP),并且它还提供了对数据库操作的支持,这主要通过Spring Data JPA和Java Persistence API(JPA)实现。 Spring注解是Spring框架中的一大特色,它极大...

    JPA注解 和hibernate 建表

    JPA注解和Hibernate建表 一、JPA概述 Java Persistence API(JPA)是Sun官方提出的Java持久化规范,它只是一个规范不是一个产品。JPA的主要目标是提供一种简洁、易用的方式来访问、操作和管理Java应用程序中的数据...

Global site tag (gtag.js) - Google Analytics