SSH框架搭建学习(一)

本文探讨了Hibernate框架作为ORM技术在Java应用与数据库交互中的优势与局限,包括其强大的功能、支持面向对象特性、良好的可移植性和开源可扩展性,同时也指出其不适合大量使用存储过程和大批量数据库操作的场景。文章还详细介绍了Hibernate环境的搭建步骤,包括依赖包导入、配置文件设置及持久化类与映射文件的配置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一,hibernate框架的优点

 本质:hibernate与mybatis一样都是ORM框架,是一种持久化技术

(1)hibernate框架功能强大,是Java应用与关系数据库之间的桥梁,对比JDBC方式操作数据库代码量大大减少,提高了持久化代码的开发速度,降低维护成本。(简述:简化jdbc操作,低维护成本)

(2)hibernate支持许多面向对象的特性,如组合,继承,多态等,使得开发人员不必在面向对象业务领域的对象模型和面向数据库的关系数据之间来回切换,方便开发人员进行领域驱动的面向对象的设计与开发。(简述:支持大部分面向对象特性)

(3)可移植性好。系统不会绑定在某个特定的关系型型数据库上,对于系统更换数据库,通常只需要更改Hibernater配置文件即可正常运行。(简述:不绑定于关系数据库)

关系型数据库与非关系型数据库介绍https://blog.youkuaiyun.com/aaronthon/article/details/81714528

(4)hibernate框架开源免费,可以在需要时研究源代码,改写源代码,进行功能的定制,具有可扩展性。(简述:框架开源,可扩展)

二,hibernate框架的缺点

(1)不适合以数据为中心大量使用储存过程的应用。(简述:不适合大量储存过程的应用)

原因:因为不绑定关系数据库,所以大量使用储存过程不合适。

(2)大规模的批量插入,修改和删除不适合用Hibernate。(简述:数据库大批量读写操作不适合)

原因:效率低下

三,hibernate环境搭建

 (1)导入环境包

maven中pom.xml文件配置

 <dependencies>
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>3.8.1</version>
      <scope>test</scope>
    </dependency>
    <!-- 语法分析器 -->
	<dependency>
	    <groupId>antlr</groupId>
	    <artifactId>antlr</artifactId>
	    <version>2.7.7</version>
	</dependency>
	   <!-- 各种集合类和集合工具类的封装 -->
	<dependency>
	    <groupId>commons-collections</groupId>
	    <artifactId>commons-collections</artifactId>
	    <version>3.2.1</version>
	</dependency>
	 <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <version>5.1.6</version>
    </dependency>
	<!--xml的读写-->
	<dependency>
	    <groupId>dom4j</groupId>
	    <artifactId>dom4j</artifactId>
	    <version>1.6.1</version>
	</dependency>
	<!-- 分析,编辑和创建java字节码的类库 -->
	<dependency>
	    <groupId>org.javassist</groupId>
	    <artifactId>javassist</artifactId>
	    <version>3.20.0-GA</version>
	</dependency>
	<!--java事务api-->
	<dependency>
	    <groupId>javax.transaction</groupId>
	    <artifactId>jta</artifactId>
	    <version>1.1</version>
	</dependency>
	 <!-- 日志输出 -->
	<dependency>
	    <groupId>org.slf4j</groupId>
	    <artifactId>slf4j-api</artifactId>
	    <version>1.7.25</version>
	</dependency>
	<!--提供对jpa(java持久化API规范的支持)-->
	<dependency>
	    <groupId>org.hibernate.javax.persistence</groupId>
	    <artifactId>hibernate-jpa-2.0-api</artifactId>
	    <version>1.0.1.Final</version>
	</dependency>
	<!-- hibernate核心包 -->
	<dependency>
	    <groupId>org.hibernate</groupId>
	    <artifactId>hibernate-core</artifactId>
	    <version>3.6.10.Final</version>
	</dependency>
			  
  </dependencies>

(2)创建Hibernate配置文件hibernate.cfg.xml

<?xml version="1.0" encoding="UTF-8"?>
<!-- 指定Hibernate配置文件的DTD信息 -->
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<!-- hibernate- configuration是连接配置文件的根元素 -->
<hibernate-configuration>
	<session-factory>
	  <!-- 指定连接数据库所用的驱动 -->
        <property name="connection.driver_class">com.mysql.jdbc.Driver</property>
        <!-- 数据库链接URL -->
		<property name="connection.url">jdbc:mysql://127.0.0.1/test</property>
		<!-- 数据库链接用户 -->
		<property name="connection.username">root</property>
		<!-- 数据库链接密码 -->
		<property name="connection.password">123</property>
		    <!-- 指定连接池里最大连接数 -->
        <property name="hibernate.c3p0.max_size">20</property>
        <!-- 指定连接池里最小连接数 -->
        <property name="hibernate.c3p0.min_size">1</property>
        <!-- 指定连接池里连接的超时时长 -->
        <property name="hibernate.c3p0.timeout">5000</property>
        <!-- 指定连接池里最大缓存多少个Statement对象 -->
        <property name="hibernate.c3p0.max_statements">100</property>
        <property name="hibernate.c3p0.idle_test_period">3000</property>
        <property name="hibernate.c3p0.acquire_increment">2</property>
        <property name="hibernate.c3p0.validate">true</property>
		<!-- 指定数据库方言 -->
        <property name="dialect">org.hibernate.dialect.MySQLInnoDBDialect</property>
         <!-- 根据需要自动创建数据表 -->
        <property name="hbm2ddl.auto">update</property>
        <!-- 指定session的范围和上下文 -->
        <property name="current_session_context_class">thread</property>
        <!-- 是否将运行期生成的sql输出到日志以供调试 -->
        <property name="show_sql">true</property>
        <!-- 是否格式化sql -->
        <property name="format_sql">true</property>
        
        <mapping resource="Hibernater-hbm/hibernate.hbm.xml"/>
	</session-factory>
</hibernate-configuration>

(3)持久化类和映射文件的配置

持久化类

映射文件配置信息

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC 
    "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
    "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">   
<hibernate-mapping>
	<!-- 配置实体类映射对应的表 -->
	<class name="cn.jbit.pojo.User" table="user">
	<!-- 配置主键,name实体类属性,type实体类对应属性类型,column表中对应列 -->
		<id name="id" type="int" column="id">
			<generator class="assigned"></generator>
		</id>
		<!-- 第一种配置方法 -->
		<property name="name" type="java.lang.String" column="name"/>
		<!-- 第二种配置方法 -->
		<property name="pwd" type="java.lang.String" >
			<column name="pwd"></column>
		</property>
	</class>
</hibernate-mapping>

测试

目录

测试结果:

测试表

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值