电脑桌面
添加小米粒文库到电脑桌面
安装后可以在桌面快捷访问

HibernateID

HibernateID_第1页
1/17
HibernateID_第2页
2/17
HibernateID_第3页
3/17
Hibernate 的主键生成器集锦 (1) increment 对long、int 或 short 的数据列生成自动增长主键。这种情况主要用于数据库中未把表格主键设置为自增,而又想表格主键自增时。 此方式的实现机制为在当前应用实例中维持一个变量,以保存着当前的最大值,之后每次需要生成主键的时候将此值加1作为主键。 这种方式可能产生的问题是:如果当前有多个实例访问同一个数据库,那么由于各个实例各自维护主键状态,不同实例可能生成同样的主键,从而造成主键重复异常。因此,如果同一数据库有多个实例(也就是并发量大的)访问,此方式必须避免使用。 只有在没有其他进程往同一张表中插入数据时才能使用。但是它的生成标识符机制不依赖于底层数据库系统,所以他适合于所有的数据库系统。 (2)identity 对如 SQL Server,MySQL 等支持自动增长列的数据库,如果数据列的类型是 long、short 或 int,可使用该主键生成器来生成自动增长主键。但由于它依赖于底层数据库,所以要求底层数据系统必须支持自动增长字段类型。而且它需要底层数据库把主键定义为自动增长字段类型。 (3)native 该生成器依据底层数据库对自动生成标识符的支持能力,来选择使用 identity、sequence或 hilo标识符生成器。能自动判断底层数据库提供的生成标识符的机制。 适合于跨数据库平台开发,即同一个 Hibernate应用需要连接多种数据库系统的场合。 (4)sequence 对如 Oracle,DB2等支持 Sequence 的数据库,如果数据列的类型是 long,short 或 int,可使用该主键生成器生成自动增长主键。 该标识符生成器利用底层数据库提供的序列来生成标识符。 tester_id_seq 在生成的 DDL 代码中会生成: create sequence tester_id_seq; 注:MySQL 不支持 sequence。 当 Hibernate 在持久化一个 SequenceTester 对象时,先从底层数据库的 tester_id_seq序列中获得一个唯一的序列号,再把它作为主键值。注意:要求底层数据库必须支持序列,包括:Oracle、DB2、SAP DB、PostgreSQL 等。 自动生成的意思是你指定一个序列给hibernate,hibernate 会找到序列的下一个值给你的主键 比如你创建一个序列CREATE SEQUENCE user_id_seq INCREMENT BY 1 -- 每次加1 START WITH 1:从1开始计数; NOMAXVALUE:不设置最大值; NOCYCLE:一直累加,不循环 ;NOCACHE :...

1、当您付费下载文档后,您只拥有了使用权限,并不意味着购买了版权,文档只能用于自身使用,不得用于其他商业用途(如 [转卖]进行直接盈利或[编辑后售卖]进行间接盈利)。
2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。
3、如文档内容存在违规,或者侵犯商业秘密、侵犯著作权等,请点击“违规举报”。

碎片内容

确认删除?
VIP
微信客服
  • 扫码咨询
会员Q群
  • 会员专属群点击这里加入QQ群
客服邮箱
回到顶部