快上网专注成都网站设计 成都网站制作 成都网站建设
成都网站建设公司服务热线:028-86922220

网站建设知识

十年网站开发经验 + 多家企业客户 + 靠谱的建站团队

量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决

Hibernate实例分析

这篇文章主要介绍“Hibernate实例分析”,在日常操作中,相信很多人在Hibernate实例分析问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Hibernate实例分析”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

创新互联是一家专注于网站设计制作、网站设计与策划设计,牙克石网站建设哪家好?创新互联做网站,专注于网站建设10余年,网设计领域的专业建站公司;建站业务涵盖:牙克石等地区。牙克石做网站价格咨询:13518219792

Hibernate(目前使用的版本是3.2)中提供了多种生成主键的方式。然而当前的这么多种生成方式未必能满足我们的要求。比如increment,可以在一个Hibernate实例的应用上很方便的时候,但是在集群的时候就不行了。再如 identity ,sequence ,native 是数据局提供的主键生成方式,往往也不是我们需要,而且在程序跨数据库方面也体现出不足。还有基于算法的生成方式生成出来的主键基本都是字符串的。

我们现在需要一种生成方式:使用Long作为主键类型,自动增,支持集群。那么我们需要自定义一个我们的主键生成器才能实现了。

Hibernate实例代码:

  1. package hibernate;  

  2.  

  3. import java.io.Serializable;  

  4. import java.sql.Connection;  

  5. import java.sql.PreparedStatement;  

  6. import java.sql.ResultSet;  

  7. import java.sql.SQLException;  

  8. import java.util.Properties;  

  9.  

  10. import org.apache.commons.logging.Log;  

  11. import org.apache.commons.logging.LogFactory;  

  12. import org.hibernate.HibernateException;  

  13. import org.hibernate.MappingException;  

  14. import org.hibernate.dialect.Dialect;  

  15. import org.hibernate.engine.SessionImplementor;  

  16. import org.hibernate.id.Configurable;  

  17. import org.hibernate.id.IdentifierGenerator;  

  18. import org.hibernate.id.PersistentIdentifierGenerator;  

  19. import org.hibernate.type.Type;  

  20.  

  21. public class IncrementGenerator implements IdentifierGenerator, Configurable {  

  22. private static final Log log = LogFactory.getLog(IncrementGenerator.class);  

  23. private Long next;  

  24. private String sql;  

  25. public Serializable generate(SessionImplementor session, Object object)  

  26. throws HibernateException {  

  27. if (sql!=null) {  

  28. getNext( session.connection() );  

  29. }  

  30. return next;  

  31. }  

  32.  

  33. public void configure(Type type, Properties params, Dialect d) 
    throws MappingException {  

  34. String table = params.getProperty("table");  

  35. if (table==null) table = params.
    getProperty(PersistentIdentifierGenerator.TABLE);  

  36. String column = params.getProperty("column");  

  37. if (column==null) column = params.
    getProperty(PersistentIdentifierGenerator.PK);  

  38. String schema = params.getProperty
    (PersistentIdentifierGenerator.SCHEMA);  

  39. sql = "select max("+column +") from " + 
    ( schema==null ? table : schema + '.' + table );  

  40. log.info(sql);  

  41. }  

  42.  

  43. private void getNext(Connection conn) throws HibernateException {  

  44. try {  

  45. PreparedStatement st = conn.prepareStatement(sql);  

  46. ResultSet rs = st.executeQuery();  

  47. if ( rs.next() ) {  

  48. next = rs.getLong(1) + 1;  

  49. }  

  50. else {  

  51. next = 1l;  

  52. }  

  53. }catch(SQLException e)  

  54. {  

  55. throw new HibernateException(e);  

  56. }  

  57. finally {  

  58. try{  

  59. conn.close();  

  60. }catch(SQLException e)  

  61. {  

  62. throw new HibernateException(e);  

  63. }  

  64. }  

  65. }  

配置:
在对应的hbm文件里面将id的配置如下:

  

到此,关于“Hibernate实例分析”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注创新互联网站,小编会继续努力为大家带来更多实用的文章!


当前文章:Hibernate实例分析
网站网址:http://6mz.cn/article/jiidie.html

其他资讯