oracle 主键自动生成

我在用jdbc操作oracle数据库的时候希望能使表自动生成主键,所以建了sequence,我可以用存储过程喝触发器实现这个功能。但是这样就不能在java段插入是及时得到... 我在用jdbc操作oracle数据库的时候希望能使表自动生成主键,所以建了sequence,我可以用存储过程喝触发器实现这个功能。但是这样就不能在java段插入是及时得到刚插入的主键。在java段直接调用select my_sequence.nextval from dual,然后在插入可以做到,可是又执行了两次数据库操作!!!使用hibernate的时候它好像不用做以上操作也能及时得到主键,不知其中原理,,哎!!不知道大家可有什么高见。。。 展开
 我来答
竟然可以七个字
2011-12-08 · TA获得超过285个赞
知道小有建树答主
回答量:233
采纳率:100%
帮助的人:172万
展开全部
hibernate的配置文件里不是有主键生成策略的配置吗?可以手动指定,也可以自动生成的。

hibernate主键生成机制
1) assigned
主键由外部程序负责生成,无需Hibernate参与。

2) hilo
通过hi/lo 算法实现的主键生成机制,需要额外的数据库表保存主
键生成历史状态。

3) seqhilo
与hilo 类似,通过hi/lo 算法实现的主键生成机制,只是主键历史
状态保存在Sequence中,适用于支持Sequence的数据库,如Oracle。

4) increment
主键按数值顺序递增。此方式的实现机制为在当前应用实例中维持
一个变量,以保存着当前的最大值,之后每次需要生成主键的时候
将此值加1作为主键。
这种方式可能产生的问题是:如果当前有多个实例访问同一个数据
库,那么由于各个实例各自维护主键状态,不同实例可能生成同样
的主键,从而造成主键重复异常。因此,如果同一数据库有多个实
例访问,此方式必须避免使用。

5) identity
采用数据库提供的主键生成机制。如DB2、SQL Server、MySQL
中的主键生成机制。

6) sequence
采用数据库提供的sequence 机制生成主键。如Oralce 中的
Sequence。

7) native
由Hibernate根据底层数据库自行判断采用identity、hilo、sequence
其中一种作为主键生成方式。

8) uuid.hex
由Hibernate基于128 位唯一值产生算法生成16 进制数值(编码后
以长度32 的字符串表示)作为主键。

9) uuid.string
与uuid.hex 类似,只是生成的主键未进行编码(长度16)。在某些
数据库中可能出现问题(如PostgreSQL)。

10) foreign
使用外部表的字段作为主键。
一般而言,利用uuid.hex方式生成主键将提供最好的性能和数据库平台适
应性。
匿名用户
2011-12-07
展开全部
找个群加进去问不就行了吗?
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式