`

JPA使用指南 javax.persistence的注解配置

    博客分类:
  • java
阅读更多
JPA注解持久化类很方便,需要jar包:ejb3-persistence.jar。我用以下三个类来说明用法。
sh原创 转载请注明:http://67566894.iteye.com/blog/659829
@SuppressWarnings("serial")
@Entity
@Table(name="T_X")
public class X implements Serializable
{
	@Id
	@GeneratedValue(strategy = GenerationType.AUTO)
	private int id;

	@Column(length=32)
	private String name;
	
         @Transient   //表示此数据不在数据库表里建立属性
         private String temp;

	@Temporal(TemporalType.TIMESTAMP) //这个是带时分秒的类型
	private Date date;

	@OneToOne(cascade = CascadeType.ALL, mappedBy = "x")
	private A a;
}
@SuppressWarnings("serial")
@Entity
@Table(name="T_A")
public class A implements Serializable
{
	@Id
	@GeneratedValue(strategy = GenerationType.AUTO)
	private int id;

	@OneToMany(cascade = CascadeType.ALL, mappedBy = "a", fetch = FetchType.EAGER)
	private List<B> b = new ArrayList<B>();

	@OneToOne()
	@JoinColumn(name = "x_Id") //加这句后就会双方共同维护关系
	private X x;
}

@SuppressWarnings("serial")
@Entity
public class B implements Serializable{
         @Id
	@GeneratedValue(strategy = GenerationType.AUTO)
	protected int id;

	@ManyToOne()
	@JoinColumn(name = "a_id")
	protected A a;
}


要注意的是:fetch = FetchType.EAGER这句话在一个类里面只能出现一次,出现两次就会报错“cannot simultaneously fetch multiple bags”,要把其他的改为fetch = FetchType.LAZY延迟加载就可以了。听说把List集合改为Set也能解决这个错误。

其他要点:
1、@Table(name="T_X")这句话可以不写,不写就已类名作为表名

2、如果想让两个类的属性生成一个数据表,在一个类里这样加入另一个类即可: @Embedded
private C c;

3、如果想要一个类继承另一个类的所有属性,则在父类里这样写:
@SuppressWarnings("serial")
@Entity
@MappedSuperclass   //增加这一行
并把父类的所有属性的private改为protected即可

4、建议在一对多关联中在"一"方用延迟加载"多"方可以在HQL中显式的"迫切左外连接" left join fetch 这样做Hibernate可以少访问数据库,也可以用"@BatchSize(size = 5)"来减少访问数据库的次数


1. @Id 声明属性为主键


2. @GeneratedValue表示主键是自动生成策略,一般该注释和 @Id 一起使用


3. @Entity 任何 hibernte 映射对象都要有次注释


4. @Table(name = “tablename”) 类声明此对象映射到哪个表


5. @Column(name = “Name”,nullable=false,length=32) 声明数据 库字段和类属性对应关系


6. @Lob 声明字段为 Clob 或 Blob 类型



7. @OneToMany(mappedBy=”order”,cascade = CascadeType.ALL, fetch = FetchType.LAZY)
   @OrderBy(value = “id ASC”)
   一对多声明,和 ORM 产品声明类似,一看就明白了。
   @ManyToOne(cascade=CascadeType.REFRESH,optional=false)
   @JoinColumn(name = “order_id”)
   声明为双向关联


8. @Temporal(value=TemporalType.DATE) 做日期类型转换。



9. @OneToOne(optional= true,cascade = CascadeType.ALL, mappedBy = “person”)
   一对一关联声明
   @OneToOne(optional = false, cascade = CascadeType.REFRESH)
   @JoinColumn(name = “Person_ID”, referencedColumnName = “personid”,unique = true)
   声明为双向关联



10. @ManyToMany(mappedBy= “students”)
   多对多关联声明。
  @ManyToMany(cascade = CascadeType.PERSIST, fetch = FetchType.LAZY)
  @JoinTable(name = “Teacher_Student”,
    joinColumns = {@JoinColumn(name = “Teacher_ID”, referencedColumnName = “teacherid”)},
    inverseJoinColumns = {@JoinColumn(name = “Student_ID”, referencedColumnName =
    “studentid”)})
   多对多关联一般都有个关联表,是这样声明的!



11. @Transiten表示此属性与表没有映射关系,是一个暂时的属性



12. @Cache(usage= CacheConcurrencyStrategy.READ_WRITE)表示此对象应用缓存


JPA规范
@Entity:通过@Entity注解将一个类声明为一个实体bean

@Table:通过 @Table注解可以为实体bean映射指定表,name属性表示实体所对应表的名称,如果没有定义 @Table,那么系统自动使用默认值:实体的类名(不带包名)

@Id:用于标记属性的主键

@Column:表示持久化属性所映射表中的字段,如果属性名与表中的字段名相同,则可以省略@Column注解,另外有两种方式标记,一是放在属性前,另一种是放在getter方法前,例如:

@Column(name = "EMPLOYEE_NAME")

private String employee_name; 或者

@Column(name = "EMPLOYEE_NAME")

public String getEmployee_name() {

return employee_name;

} 这两种方式都是正解的,根据个人喜好来选择。大象偏向于第二种,并且喜欢将属性名与字段名设成一样的,这样可以省掉@Column注解,使代码更简洁。



@Temporal(TemporalType.DATE):如果属性是时间类型,因为数据表对时间类型有更严格的划分,所以必须指定具体时间类型,如④所示。在javax.persistence.TemporalType枚举中定义了3种时间类型:

通过 @Temporal 定义映射到数据库的时间精度:
@Temporal(TemporalType.DATE)       日期
@Temporal(TemporalType.TIME)       时间
@Temporal(TemporalType.TIMESTAMP) 两者兼具

                 

@Temporal只是起映射作为



@Transient  

@Target({METHOD, FIELD}) @Retention(RUNTIME)

public @interface Transient {}

指明一个属性或方法不能持久化





@TableGenerator:表生成器,将当前主键的值单独保存到一个数据库表中,主键的值每次都是从指定的表中查询来获得,这种生成主键的方式是很常用的。这种方法生成主键的策略可以适用于任何数据库,不必担心不同数据库不兼容造成的问题。大象推荐这种方式管理主键,很方便,集中式管理表的主键,而且更换数据库不会造成很大的问题。各属性含义如下:

        name:表示该表主键生成策略的名称,这个名字可以自定义,它被引用在@GeneratedValue中设置的"generator"值中

        table:表示表生成策略所持久化的表名,说简单点就是一个管理其它表主键的表,本例中,这个表名为GENERATOR_TABLE

        pkColumnName:表生成器中的列名,用来存放其它表的主键键名,这个列名是与表中的字段对应的

        pkColumnValue:实体表所对应到生成器表中的主键名,这个键名是可以自定义滴

        valueColumnName:表生成器中的列名,实体表主键的下一个值,假设EMPLOYEE表中的EMPLOYEE_ID最大为2,那么此时,生成器表中与实体表主键对应的键名值则为3

        allocationSize:表示每次主键值增加的大小,例如设置成1,则表示每次创建新记录后自动加1,默认为50

             

             

@Target({METHOD, FIELD}) @Retention(RUNTIME)

public @interface OneToMany {

String targetEntity() default "";

CascadeType[] cascade() default {};

FetchType fetch() default LAZY;

String mappedBy() default "";

}


String targetEntity (Optional) The fully qualified class name of

the entity class that is the target of the association.

Optional only if the Collection property

is defined using Java generics. Must be

specified otherwise.

The parameter type of the

Collection when defined

using generics(Generics泛型),    如果使用泛型,就可省略指明targetEntity

CascadeType[] cascade (Optional) The operations that should be cascaded

to the target of the association

No operations are cascaded

FetchType fetch (Optional) Whether the association should be

lazy loaded or eagerly fetched.

FetchType.LAZY    默认为延迟加载

String mappedBy (Optional) The field that owns the relationship

指多的一方关联的属性名

mappedBy指定的是不需要维护关系的一端  ??



@Target({METHOD, FIELD}) @Retention(RUNTIME)

public @interface ManyToOne {

String targetEntity() default "";

CascadeType[] cascade() default {};

FetchType fetch() default EAGER;

boolean optional() default true;

}


targetEntity (Optional) The fully qualified class name of the entity class that is the target of the associationThe type of the property that stores the association

是指一方的实体类型的class  ,默认的就是这个属性的类型。其实有些可以省略掉



CascadeType[] cascade (Optional) The operations that should be cascaded

to the target of the association No operations are cascaded

FetchType fetch (Optional) Whether the association should be

lazy loaded or eagerly fetched.      FetchType.EAGER   默认为主动加载

boolean optional (Optional) Whether the association is optional.

If set to false then a non-null relationship must  always exist.

true



@Target({METHOD, FIELD}) @Retention(RUNTIME)

public @interface OneToOne {

String targetEntity() default "";

CascadeType[] cascade() default {};

FetchType fetch() default EAGER;

boolean optional() default true;

String mappedBy() default "";

boolean usePKasFK() default false;

}





The JoinColumn annotation is used to specify a mapped column for joining an entity association or a

secondary table.

@Target({TYPE, METHOD, FIELD}) @Retention(RUNTIME)

public @interface JoinColumn {

String name() default "";

String referencedColumnName() default "";

boolean primaryKey() default false;

boolean unique() default false;

boolean nullable() default true;

boolean insertable() default true;

boolean updatable() default true;

String columnDefinition() default "";

String secondaryTable() default "";

}


@Target({METHOD, FIELD}) @Retention(RUNTIME)

public @interface ManyToMany {

String targetEntity() default "";

CascadeType[] cascade() default {};

FetchType fetch() default LAZY;

String mappedBy() default "";

}
11
0
分享到:
评论
7 楼 spoony_peng 2012-11-15  
学习
6 楼 nforce_com 2011-03-30  
5 楼 ch21 2010-06-21  
写的很好,如果可以把相应的源代码贴上就更好了,因为有些entity猛地一出现,譬如,有时候是person,有时候是student.
4 楼 67566894 2010-05-18  
一对多怎么会有中间表呀? 你是不是写成<many-to-many>了
3 楼 wqmain 2010-05-15  
请问我有这样的需求,就是A对B单向一对多关联,即在A端对属性b声明:
@OneToMany(cascade = CascadeType.ALL, fetch = FetchType.EAGER)
而B中不配置@ManyToOne,这样会生成一个中间表,但同时还会在这个中间表中对b_id创建一个唯一索引,而这是不应该的!!!
请问加什么注解才不会创建这个索引?  多谢赐教!!! 
2 楼 xzcgeorge 2010-05-12  
少了一个many to many。 要是加上就完美了。
1 楼 steafler 2010-05-11  
OneToMany的时候应该用LAZY才对吧,不然内存受不了啊。

相关推荐

    JPA规范注解的javax.persistence包

    JPA规范注解的javax.persistence包 ejb3-persistence.jar

    JPA2.0 javax.persistence src 源码

    JPA2.0 javax.persistence src 源码

    javax.persistence.Entity 的jar包文件

    这是一个javax.persistence.Entity 的jar包文件。有时候创建JPA工程导入EclipseLink库的时候会缺少这种文件,可以选择在库中加入这个jar包即可

    javax.persistence-2.0.0.jar

    javax.persistence-2.0.0.jar 解决Hibernate JPA不兼容问题。

    javax.persistence-2.0.5.jar

    基于git事务82dd749的javax.persistence构建 org.eclipse.persistence/javax.persistence/2.0.5/javax.persistence-2.0.5.jar

    javax.persistence-2.2.1.jar

    基于git事务82dd749的javax.persistence构建 org.eclipse.persistence/javax.persistence/2.2.1/javax.persistence-2.2.1.jar

    hibernate-jpa-2.1-api-1.0.2.Final-API文档-中英对照版.zip

    标签:hibernate、javax、persistence、jpa、api、中英对照文档、jar包、java; 使用方法:解压翻译后的API文档,用浏览器打开“index.html”文件,即可纵览文档内容。 人性化翻译,文档中的代码和结构保持不变,...

    javax.persistence-2.1.1.jar

    基于git事务82dd749的javax.persistence构建 org.eclipse.persistence/javax.persistence/2.1.1/javax.persistence-2.1.1.jar

    javax.persistence-2.2.0-RC1.jar

    基于git事务82dd749的javax.persistence构建 org.eclipse.persistence/javax.persistence/2.2.0-RC1/javax.persistence-2.2.0-RC1.jar

    javax.persistence-2.2.0-RC2.jar

    基于git事务82dd749的javax.persistence构建 org.eclipse.persistence/javax.persistence/2.2.0-RC2/javax.persistence-2.2.0-RC2.jar

    Hibernate注解.docx

    (1)使用的均为javax.persistence.Transient包中的注解 (2)不再需要映射文件了 (3)在Hibernate主配置文件中无需指定映射文件了,但需要指定注解的实体类。(springboot这一步也省了) 注解的具体文档在javax....

    SSJ SpringMVC3+JPA2.0(Hibernate4)+FreeMarker

    调试@Test报错javax.persistence.spi.PersistenceUnitInfo.getSharedCacheMode()Ljavax/persistence/SharedCacheMode; 部署正常,求解决方案。谢谢

    javax.persistence-2.1.0-RC1.jar

    基于git事务82dd749的javax.persistence构建 org.eclipse.persistence/javax.persistence/2.1.0-RC1/javax.persistence-2.1.0-RC1.jar

    javax-persistence-api 1.2 src

    JPA1.2 JavaEE 5 从glassfish源码里面拷贝的 稍微做了点改动 主要是将参数泛型化了,比如:Map map -&gt; Map,String&gt; map Class cls --&gt; Class&lt;?&gt; cls 涉及到核心的地方的源码基本没动

    spring-framework-3.0.5.RELEASE-dependencies-5

    javax.persistence javax.portlet javax.resource javax.servlet javax.transaction javax.validation javax.xml.bind javax.xml.rpc javax.xml.soap javax.xml.stream javax.xml.ws net.sourceforge.cglib ...

    spring-framework-3.0.5.RELEASE-dependencies-1

    javax.persistence javax.portlet javax.resource javax.servlet javax.transaction javax.validation javax.xml.bind javax.xml.rpc javax.xml.soap javax.xml.stream javax.xml.ws net.sourceforge.cglib ...

    spring-framework-3.0.5.RELEASE-dependencies-3

    javax.persistence javax.portlet javax.resource javax.servlet javax.transaction javax.validation javax.xml.bind javax.xml.rpc javax.xml.soap javax.xml.stream javax.xml.ws net.sourceforge.cglib ...

    spring-framework-3.0.5.RELEASE-dependencies-2

    javax.persistence javax.portlet javax.resource javax.servlet javax.transaction javax.validation javax.xml.bind javax.xml.rpc javax.xml.soap javax.xml.stream javax.xml.ws net.sourceforge.cglib ...

    spring-framework-3.0.5.RELEASE-dependencies-8

    javax.persistence javax.portlet javax.resource javax.servlet javax.transaction javax.validation javax.xml.bind javax.xml.rpc javax.xml.soap javax.xml.stream javax.xml.ws net.sourceforge.cglib ...

    spring-framework-3.0.5.RELEASE-dependencies-6

    javax.persistence javax.portlet javax.resource javax.servlet javax.transaction javax.validation javax.xml.bind javax.xml.rpc javax.xml.soap javax.xml.stream javax.xml.ws net.sourceforge.cglib ...

Global site tag (gtag.js) - Google Analytics