码迷,mamicode.com
首页 > 数据库 > 详细

[转] hibernate Mysql 自增长 注解配置,表无关联的注解方式关联查询

时间:2015-08-27 00:10:06      阅读:253      评论:0      收藏:0      [点我收藏+]

标签:

不同数据库 自增长ID配置

正对不同的数据库可以同时使用
        @Id
        @GeneratedValue(strategy = GenerationType.AUTO)


2 针对mysql
 @Id
 @GeneratedValue(strategy = GenerationType.IDENTITY)


3 针对oracle
       @Id
       @GeneratedValue(strategy = GenerationType.SEQUENCE,generator="s_gen")
       @SequenceGenerator(name="s_gen",sequenceName="s_seq")


无关联表 关联查询配置

1、FetchType.LAZY:懒加载,加载一个实体时,定义懒加载的属性不会马上从数据库中加载。

2、FetchType.EAGER:急加载,加载一个实体时,定义急加载的属性会立即从数据库中加载。

3、比方User类有两个属性,name跟address,就像百度知道,登录后用户名是需要显示出来的,此属性用到的几率极大,要马上到数据库查,用急加载;而用户地址大多数情况下不需要显示出来,只有在查看用户资料是才需要显示,需要用了才查数据库,用懒加载就好了。所以,并不是一登录就把用户的所有资料都加载到对象中,于是有了这两种加载模式。

name 是当前实体 属性   referencedColumnName 是与之关联的实体 属性

fetch=FetchType.LAZY)延迟加载关联表 不要乱用 有时候要爆胎

  @ManyToOne(targetEntity=UnitOrganizations.class,fetch=FetchType.LAZY)

    @JoinColumn(name="org_Id",referencedColumnName="id",updatable=false,insertable=false)

  public UnitOrganizations getOrganizations() {

    return organizations;

    }


建议在一多对关联中在"一"方用延迟加载"多"方

可以在HQL中显式的"迫切左外连接" left join fetch
这样做Hibernate可以少访问数据库,也可以用"@BatchSize(size = 5)"来减少访问数据库的次数

[转] hibernate Mysql 自增长 注解配置,表无关联的注解方式关联查询

标签:

原文地址:http://www.cnblogs.com/ZhuRenWang/p/4761992.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!