zoukankan      html  css  js  c++  java
  • 指定hibernate 中annotation的映射类型

    1. 基本属性映射

    通过 @Basic 可以声明属性的存取策略:

    @Basic(fetch=FetchType.EAGER)   即时获取(默认的存取策略)

    @Basic(fetch=FetchType.LAZY)    延迟获取

    通过 @Temporal 定义映射到数据库的时间精度:

    @Temporal(TemporalType=DATE)       日期

    @Temporal(TemporalType=TIME)       时间

    @Temporal(TemporalType=TIMESTAMP)  两者兼具

    使用 @Lob 映射Blob或Clob类型:根据属性类型决定

    java.sql.CLOB, Character[], char[], String 将映射为 Clob

    java.sql.BLOB, Byte[], byte[], serializable 将映射为 Blob

    2. 列属性映射

    使用 @Column 映射到列

    @Column(

    name="columnName";    // 可选,列名(默认是属性名)

    boolean unique() default false;  // 可选,是否在该列上设置唯一约束(默认 false)

    boolean nullable() default true; // 可选,是否可以为空

    boolean insertable() default true; // 可选,该列是否作为生成insert语句中的一列

    boolean updatable() default true;  // 可选,该列是否作为生成update语句中的一列

    String columnDefinition() default ""; // 可选,为这个特定列覆盖 SQL DDL 片段(可能导致无法在不同数据库间移植)

    String table() default "";  // 可选,定义对应的表,默认为主表

    int length() default 255;   // 可选,列长度

    int precision() default 0; // 可选,列十进制精度(decimal precision)

    int scale() default 0; // 可选, 列十进制数范围(decimal scale)

    public class Person {

        @Column(name = "PERSONNAME", unique = true, nullable = false, updatable = true)

        private String name;

        @Column(name = "PHOTO", columnDefinition = "BLOB NOT NULL", secondaryTable="PER_PHOTO")

        private byte[] picture;

    }

     

    宝贝网址:

  • 相关阅读:
    SqlCacheDependency [转]
    C#导出Word [ZT]
    ADO.NET Entity Framework 学习(1) [ZT]
    AJAX, JSON.js,Newtonsoft.Json.dll,nunit.framework.dll 源代码
    ADO.NET 1.1和2.0事务的区别
    Sql Server 2000 中游标的使用示例 [ZT]
    如何检测是否安装了.NET 2.0和.NET 3.0 [ZT]
    ORACLE 常用函数 [ZT]
    Resource 学习笔记
    GridView 双击选择行 [ZT]
  • 原文地址:https://www.cnblogs.com/W203654/p/2341470.html
Copyright © 2011-2022 走看看