1005--<id>

.映射对象标识符

Hibernate 使用对象标识符 (OID) 来建立内存中的对象和数据库表中记录的对应关系 .
  对象的 OID 和数据表的主键对应 . Hibernate 通过标识符生成器来为主键赋值
Hibernate 推荐在数据表中使用 代理主键 , 即不具备业务含义的字段 .
   代理主键通常为整数类型 , 因为整数类型比字符串类型要节省更多的数据库空间 .
在对象 - 关系映射文件中 , <id> 元素用来设置对象标识符 . <generator> 子元素用来设定标识符生成器 .
Hibernate 提供了标识符生成器接口 : IdentifierGenerator , 并提供了各种内置实现

 

id :设定持久化类的 OID 和表的主键的映射
name : 标识持久化类 OID 的属性名 
column : 设置标识属性所映射的 数据表的 列名 ( 主键字段的名字 ).
unsaved-value : 若设定了该属性 , Hibernate 会通过比较持久化类的
  OID 值和该属性值来区分当前持久化类的对象是否为临时对象
type : 指定 Hibernate 映射类型 . Hibernate 映射类型是 Java 类型与 SQL 类型的桥梁 .
      如果没有为某个属性显式设定映射类型 , Hibernate 会运用反射机制先识别出
     持久化类的特定属性的 Java 类型 , 然后自动使用与之对应的默认的 Hibernate 映射类型
Java 的基本数据类型和包装类型对应相同的 Hibernate 映射类型 .
  基本数据类型无法表达 null, 所以对于持久化类的 OID 推荐使用包装类型
generator :设定持久化类设定标识符生成器
  – class: 指定使用的标识符生成器全限定类名或其缩写名
 
.主键生成策略generator
Hibernate 提供的内置标识符生成器 :
 
.increment 标识符生成器
increment 标识符生成器 Hibernate 以递增的方式为代理主键赋值
Hibernate 会先读取 NEWS 表中的主键的最大值 ,
  而接下来向 NEWS 表中插入记录时 , 就在 max(id) 的基础上递增 , 增量为 1.
适用范围 :
由于 increment 生存标识符机制不依赖于底层数据库系统 , 因此它适合所有的数据库系统
适用于只有单个 Hibernate 应用进程 访问同一个数据库的场合 , 在集群环境下不推荐使用它
OID 必须为 long, int short 类型 , 如果把 OID 定义为 byte 类型 , 在运行时会抛出异常
 
.sequence 标识符生成器
sequence  标识符生成器利用底层数据库提供的序列来生成标识符 .
Hibernate 在持久化一个 News 对象时 , 先从底层数据库的 news_seq 序列中获得一个唯一的标识号 , 再把它作为主键值
适用范围 :
由于 sequence 生成标识符的机制依赖于底层数据库系统的序列 , 因此 , 要求底层数据库系统必须支持序列 . 支持序列的数据库包括 : DB2, Oracle
OID 必须为 long, int short 类型 , 如果把 OID 定义为 byte 类型 , 在运行时会抛出异常
 
hilo标识符生成器
hilo 标识符生成器由 Hibernate 按照一种 high/low 算法*生成标识符 , 它从数据库的特定表的字段中获取 high .
Hibernate 在持久化一个 News 对象时 , Hibernate 负责生成主键值 .
  hilo 标识符生成器在生成标识符时 , 需要读取并修改 HI_TABLE 表中的 NEXT_VALUE .
适用范围 :
由于 hilo 生存标识符机制不依赖于底层数据库系统 , 因此它适合所有的数据库系统
OID 必须为 long, int short 类型 , 如果把 OID 定义为 byte 类型 , 在运行时会抛出异常
 
native 标识符生成器
native 标识符生成器依据底层数据库对自动生成标识符的支持能力 , 来选择使用 identity,sequence hilo 标识符生成器 .
适用范围 :
由于 native 能根据底层数据库系统的类型 , 自动选择合适的标识符生成器 , 因此很适合于跨数据库平台开发
OID 必须为 long, int short 类型 , 如果把 OID 定义为 byte 类型 , 在运行时会抛出异常
为以下代码增加修改部门成员的功能:#include <stdio.h> #include <stdlib.h> #include <string.h> // 定义一个学生结构体 typedef struct student { char name[20]; // 姓名 int id; // 学号 char dept[20]; // 部门 struct student *next; // 下一个学生 struct student *child; // 第一个子节点 } Student; // 定义一个全局变量,存储学生会组织架构 Student *root = NULL; // 添加一个新的学生到指定的部门中 void addStudent(char *dept, char *name, int id) { // 创建一个新的学生节点 Student *newStudent = (Student*)malloc(sizeof(Student)); strcpy(newStudent->name, name); newStudent->id = id; strcpy(newStudent->dept, dept); newStudent->next = NULL; newStudent->child = NULL; // 如果学生会组织架构为空,则新节点为根节点 if (root == NULL) { root = newStudent; return; } // 查找指定部门的最后一个学生节点 Student *cur = root; while (cur != NULL) { if (strcmp(cur->dept, dept) == 0) { while (cur->next != NULL) { cur = cur->next; } cur->next = newStudent; return; } cur = cur->child; } // 如果指定部门不存在,则创建新的部门节点 Student *newDept = (Student*)malloc(sizeof(Student)); strcpy(newDept->name, dept); newDept->id = -1; newDept->next = NULL; newDept->child = newStudent; // 将新部门节点插入到学生会组织架构中 cur = root; while (cur->child != NULL) { cur = cur->child; } cur->child = newDept; } // 根据学号查找学生信息 Student *findStudent(int id) { Student *cur = root; while (cur != NULL) { Student *s = cur->child; while (s != NULL) { if (s->id == id) { return s; } s = s->next; } cur = cur->child; } return NULL; } // 输出指定部门的所有学生信息 void printDept(char *dept) { Student *cur = root; while (cur != NULL) { if (strcmp(cur->dept, dept) == 0) { printf("%s部门成员:\n", dept); Student *s = cur->child; while (s != NULL) { printf("姓名:%s\t学号:%d\n", s->name, s->
06-08
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值