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


    不同数据库 自增长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)"来减少访问数据库的次数

  • 相关阅读:
    Android SDK 在线更新镜像服务器
    Android Studio (Gradle)编译错误
    java ZIP压缩文件
    java文件操作(输出目录、查看磁盘符)
    JXL读取写入excel表格数据
    Linux命令zip和unzip
    Linux查看系统基本信息
    Ubuntu C++环境支持
    Linux开机执行bash脚本
    ubuntu中磁盘挂载与卸载
  • 原文地址:https://www.cnblogs.com/ZhuRenWang/p/4761992.html
Copyright © 2020-2023  润新知