文档章节

SSH入门系列8:Hibernate配置

O
 ORZ你好
发布于 2017/08/05 14:04
字数 543
阅读 10
收藏 0

搭配Hibernate环境有如下步骤:

1新建一个动态网页项目后,导入相关包。相关包在相应的required文件夹下,同时加载数据库jdbc文件

2在src目录下,新建hibernate.cfg.xml  ,该名字不建议修改,简化版本的如下:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
                                         "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
    <session-factory name="SessionFactory">
        <property name="hibernate.show_sql">true</property>
 <property name="hibernate.connection.url">jdbc:sqlserver://localhost:1433;DatabaseName=MyDataBase</property>
        <property name="hibernate.connection.username">sa</property>
        <property name="hibernate.connection.password">123456</property

<propertyname="hibernate.connection.driver_class">com.microsoft.sqlserver.jdbc.SQLServerDriver</property>
        <property name="hibernate.dialect">org.hibernate.dialect.SQLServerDialect</property>
         <property name="hibernate.connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider</property>
         <property name="hibernate.c3p0.max_size">20</property>
                  <!-- 最小连接数 -->
       <property name="hibernate.c3p0.min_size">5</property>
              <!-- 获得连接的超时时间,如果超过这个时间,会抛出异常,单位毫秒 -->
     <property name="hibernate.c3p0.timeout">120</property>
             <!-- 最大的PreparedStatement的数量 -->
      <property name="hibernate.c3p0.max_statements">100</property>
            <!-- 每隔120秒检查连接池里的空闲连接 ,单位是秒-->
      <property name="hibernate.c3p0.idle_test_period">120</property>
            <!-- 当连接池里面的连接用完的时候,C3P0一下获取的新的连接数 -->
      <property name="hibernate.c3p0.acquire_increment">2</property>
            <!-- 每次都验证连接是否可用 -->
       <property name="hibernate.c3p0.validate">true</property>

        <mapping resource="com/model/User.hbm.xml"></mapping>

3编写与数据库对应的类,比如在MyDataBase数据库下有个_login的表,分别有id ,name ,password。这时做如下设计:

public class User {
    private int id;
    private String username ;
    private String password;
    public int getId() {
        return id;
    }
    public void setId(int id) {
        this.id = id;
    }
    public String getUsername() {
        return username;
    }
    public void setUsername(String username) {
        this.username = username;
    }
    public String getPassword() {
        return password;
    }
    public void setPassword(String password) {
        this.password = password;
    }
    
}

 

4建立隐射文件User.hbm.xml,要求与类在同一个包下:

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<!-- Generated 2016-9-5 19:57:46 by Hibernate Tools 3.4.0.CR1 -->
<hibernate-mapping>
    <class name="com.model.User" table="_login">
        <id name="id" type="java.lang.Integer">
            <column name="id" />
            <generator class="native" />

//native 表示自行判断,如果用increment则表示递增


        </id>
        <property name="username" type="java.lang.String">
            <column name="name" />
        </property>
        <property name="password" type="java.lang.String">
            <column name="password" />
        </property>
    </class>
</hibernate-mapping>

 

最后一个测试程序:


        Configuration  config  =new Configuration().configure();
          SessionFactory  sessionFactory = config.buildSessionFactory();
          Session  session = sessionFactory.openSession();
          Transaction   tc = null;
          try {
              //开启事物
              tc = session.beginTransaction();
              User user = (User)session.get(User.class, new Integer(3));
              System.out.println("用户名为:"+user.getUsername()+";用户密码为:"+user.getPassword());
              //提交事物
              tc.commit();
        } catch (Exception e) {
            // 不是空值则回滚
          if (tc!=null) {
            tc.rollback();
        }
          e.printStackTrace();
        }finally{
            session.close();
        }
      }
    }

 

© 著作权归作者所有

共有 人打赏支持
O
粉丝 0
博文 15
码字总数 8932
作品 0
南京
私信 提问
Java Web学习计划

--- 本月为入门阶段,从零开始,一步一步的做出一个实用的网站。 深入学习Java语言,初步掌握前端技术,使用JSP和MySQL完成一个简单的网站 第1周 Java高级编程学习目标:
1.深入了解JDK环境...

SVD
2016/12/01
55
0
Jenkins入门系列

enkins 是一个可扩展的持续集成引擎。 主要用于: l 持续、自动地构建/测试软件项目。 l 监控一些定时执行的任务。 Jenkins拥有的特性包括: l 易于安装-只要把jenkins.war部署到servlet容器...

harries
2016/04/21
218
0
Jenkins入门系列

Jenkins 是一个可扩展的持续集成引擎。 主要用于: l 持续、自动地构建/测试软件项目。 l 监控一些定时执行的任务。 Jenkins拥有的特性包括: l 易于安装-只要把jenkins.war部署到servlet容器...

外星人et59
2016/04/21
0
0
【持久化框架】Mybatis与Hibernate的详细对比

前言 这篇博文我们重点分析一下Mybatis与Hibernate的区别,当然在前面的博文中我们已经深入的研究了Mybatis和Hibernate的原理。 Mybatis 【持久化框架】Mybatis简介与原理 【持久化框架】Spr...

sietai
05/18
0
0
Hibernate 学习资料汇总

1.Hibernate系列——总结篇(http://blog.csdn.net/jiuqiyuliang/article/details/41318751) 2.Hibernate框架简述(http://www.cnblogs.com/eflylab/archive/2007/01/09/615338.html) 3.Hiber......

IT追寻者
2016/08/06
20
0

没有更多内容

加载失败,请刷新页面

加载更多

支付宝api实现转账到单个账号

项目后台需要实现用户提现功能,支付宝平台对应的就是“单笔转账到支付宝账户”。具体实现见代码,无套路! 肯定需要先申请支付宝商户账号相关信息。以下为个人沙箱环境实现代码,生产上只需...

貔貅叔
26分钟前
3
0
Spark自定义维护kafka的offset到zk

import kafka.common.TopicAndPartitionimport kafka.message.MessageAndMetadataimport kafka.serializer.StringDecoderimport kafka.utils.ZkUtilsimport org.I0Itec.zkclient.ZkC......

hblt-j
26分钟前
2
0
bash运行脚本的几种方式

bash shell 脚本执行的方法有多种,本文作一个总结,供大家学习参考。 假设我们编写好的shell脚本的文件名为hello.sh,文件位置在/data/shell目录中并已有执行权限。 方法一:切换到shell脚本...

吴伟祥
36分钟前
2
0
看图了解RocksDB

摘要: 它是一个高性能的Key-Value数据库。设计了完善的持久化机制,同时保证性能和安全性。能够良好的支持范围查询,因为K-V记录就是按照Key来排序的。 下图为写入的流程: 可以看到主要的三...

阿里云官方博客
45分钟前
1
0
关于Python pandas模块输出每行中间省略号问题

关于Python数据分析中pandas模块在输出的时候,每行的中间会有省略号出现,和行与行中间的省略号....问题,其他的站点(百度)中的大部分都是瞎写,根本就是复制黏贴以前的版本,你要想知道其...

上官夏洛特
46分钟前
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部