Hibernate如何自动生成字符串Id
我想用Hibernate帮我自动生成字符串类型的id,比如User表里面就生成u_001、u_002,然后Member表里面的id就是m_001、m_002这样子。或者说...
我想用Hibernate帮我自动生成字符串类型的id,比如User表里面就生成u _001、u_002,然后Member表里面的id就是m_001、m_002这样子。或者说不用Hibernate,要写代码应该如何写?帮到我的话,再加分。
展开
2个回答
2013-05-18
展开全部
首先,Hibernate好像是不支持自定义ID的(不能肯定,请百度一下)。如果用代码控制,那么在创建新对象的时候做以下控制根据创建时间(比如字段CreateTime,正规的数据库设计都会有这个字段的)获得最后一次创建的那一行数据。比如这一行的ID是M_005,那么就将字符部分去掉,数字部分转换成int型再+1,然后再转回string,接着写个循环判断,如果长度小于3,那么在字符串前面加“0”,如此再加回M_,就可以实现这种ID的控制但这种做法会消耗多一些的系统资源
2013-05-18
展开全部
Hibernate是支持自定义主键生成器的。写一个类实现IdentifierGenerator, Configurable 这两个接口定义的方法。具体逻辑自己想了。大概可以获取Member表最后一条记录后自加。如果不想每次查询数据库就定义个静态代码块自加吧。自定义主键系统消耗好像挺大的。如果仅为了实现两个表的关联用one-to-one获取搞个many-to-one然后价格unque约束就可以了
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询