hibernate_sequence表.。。

今天遇到一个问题,在运行项目的时候数据库中突然出现一个 hibernate_sequence 的表,这个表并不是我建的,于是把它删了。结果项目再运行就报错了,
could not read a hi value - you need to populate the table: hibernate_sequen..

于是又默默的重新把表加回去了..这次是可以运行了,但是却不能向数据库表插入数据,查询更新却可以。不科学啊,以前都不会出现这个问题。没办法只能百度一下了,后来重新生成数据库实体类(这时候myeclipse10注册码又没用了,又各种想办法破解)结果并没有什么卵用。。。。后来又百度了一下关键词:Table not found: hibernate_sequence   找到一个页面  结果尼玛全是英文的,但是没办法貌似遇到像我类似问题的,中文都搜不到(也许是我搜索技巧不到位),只能硬着头皮看,结果看到

大致意思就是把数据库实体类的注解@GeneratedValue改成@GeneratedValue(strategy = GenerationType.IDENTITY) 没办法试一试吧,诶结果还真的可以,虽然现在还不知道为什么。。。

更新------

@GeneratedValue(strategy = GenerationType.IDENTITY)的意思是把Hibernate提供的主键生成策略设置为identity (即自增)

identity

       a)根据底层数据库,来支持自动增长,不同的数据库用不同的主键增长方式。

       b)特点: 与底层数据库有关,要求数据库支持Identity,如MySQl中是auto_increment, SQL Server 中是Identity。支持的数据库有MySql、SQL Server、DB2、Sybase和HypersonicSQL。

       c)好处:在建表的时候指定了id为自动增长,实际开发中就不需要自己定义插入数据库的主键值,系统会自动顺序递增一个值 。Identity无需Hibernate和用户的干涉,使用较为方便,但由于依赖于数据库,所以不便于在不同的数据库之间移植程序。

-----转载自 

Hibernate主键生成策略总结

  • 8
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值