Mick.987

相信开源,才是未来的春天!

 

指定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;

}

 

宝贝网址:

posted on   张朋飞  阅读(310)  评论(0编辑  收藏  举报

编辑推荐:
· 为什么说在企业级应用开发中,后端往往是效率杀手?
· 用 C# 插值字符串处理器写一个 sscanf
· Java 中堆内存和栈内存上的数据分布和特点
· 开发中对象命名的一点思考
· .NET Core内存结构体系(Windows环境)底层原理浅谈
阅读排行:
· 为什么说在企业级应用开发中,后端往往是效率杀手?
· DeepSeek 解答了困扰我五年的技术问题。时代确实变了!
· 本地部署DeepSeek后,没有好看的交互界面怎么行!
· 趁着过年的时候手搓了一个低代码框架
· 推荐一个DeepSeek 大模型的免费 API 项目!兼容OpenAI接口!

导航

统计

点击右上角即可分享
微信分享提示