Hibernate初体验

小编:管理员 307阅读 2022.09.14

由于小编最近要接手一个用Hibernate写的项目,所以就学了一下,如果之前学过Spring Date Jpa的小伙伴看起来应该很简单!

Hibernate简介

Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,它将POJO与数据库表建立映射关系,是一个全自动的orm框架,hibernate可以自动生成SQL语句,自动执行,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库。 Hibernate可以应用在任何使用JDBC的场合,既可以在Java的客户端程序使用,也可以在Servlet/JSP的Web应用中使用,最具革命意义的是,Hibernate可以在应用EJB的J2EE架构中取代CMP,完成数据持久化的重任。 ---------->来自百度

基于注解创建实体

@Entity  //实体映射
@Table(name = "user")  //数据库表白
public class User {
 
 @Id //主键id
 @GeneratedValue //主键生成方式
 private int id;
 
 @Column(name = "name") //字段名
 private String name;
 
 @Column(name = "pwd")
 private String pwd;
 
 @Column(name = "adder")
 private String adder;
 
 @Column(name = "age")
 private int age;
 
 @Column(name = "salary")
 private double salary;
复制

}

注:正规写法是将注解写在属性的get方法上

创建Dao

import com.yanghj.ssh.entity.User;

/**
* @ClassName: UserRepository  
* @Description: UserDao  
* @author yang hai ji  
* @date 2018年6月7日
*/
public interface UserRepository {

 //查询所有用户
 User findUser ();
}
复制

Dao实现

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Repository;

import com.yanghj.ssh.entity.User;
import com.yanghj.ssh.repository.UserRepository;

/**
* 
* @ClassName: UserRepositoryImpl
* @Description: 用户dao层实现
* @author yang hai ji
* @date 2018年6月7日
*/
@Repository
public class UserRepositoryImpl implements UserRepository {

 @Autowired
 private SessionFactory sessionFactory;

 private Session getCurrentSession() {
   return this.sessionFactory.openSession();
 }

 @Override
 public User findUser() {
   return (User) getCurrentSession().get(User.class, 1);
 }
 }
复制

ServiceImpl

/**
* @ClassName: UserServiceImpl  
* @Description:  用户Service实现
* @author yang hai ji  
* @date 2018年6月7日
*/
@Service
public class UserServiceImpl implements UserService {

 @Autowired
 private UserRepository userRepository;
 
 @Override
 public User findUser() {
   return userRepository.findUser();
 }
}
复制

Controller展示

/**
 * @Title: findUser  
 * @Description: 根据id查询用户 
 * @param @return    参数  
 * @return User    返回类型  
 * @throws
 */
 @RequestMapping("/findUser")
 @ResponseBody
 public User findUser(){
    return userService.findUser();
 }
复制

Spring+Hibernate

Spring + Hibernate

<beans xmlns="http://www.springframework.org/schema/beans"
     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
     xmlns:context="http://www.springframework.org/schema/context"
     xsi:schemaLocation="http://www.springframework.org/schema/beans
      http://www.springframework.org/schema/beans/spring-beans-4.1.xsd
      http://www.springframework.org/schema/context
      http://www.springframework.org/schema/context/spring-context-4.1.xsd">

  <!-- Spring对com.xrom.ssh目录下的@Repository、@Service、@@Component注解标注的bean进行自动扫描 -->
  <context:component-scan base-package="com.yanghj.ssh">
      <!-- 扫描时跳过 @Controller 注解的JAVA类(控制器) -->
      <context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
  </context:component-scan>

  <!--                             hibernate配置                          -->
  <context:property-placeholder location="classpath:/jdbc.properties"/>

  <!--配置数据源-->
  <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close">
      <property name="driverClass" value="${jdbc.driver}"/>  <!--数据库连接驱动-->
      <property name="jdbcUrl" value="${jdbc.url}"/>     <!--数据库地址-->
      <property name="user" value="${jdbc.username}"/>   <!--用户名-->
      <property name="password" value="${jdbc.password}"/>   <!--密码-->
      <property name="maxPoolSize" value="40"/>      <!--最大连接数-->
      <property name="minPoolSize" value="1"/>       <!--最小连接数-->
      <property name="initialPoolSize" value="10"/>      <!--初始化连接池内的数据库连接-->
      <property name="maxIdleTime" value="20"/>  <!--最大空闲时间-->
  </bean>

  <!--配置session工厂-->
  <bean id="sessionFactory" class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
      <property name="dataSource" ref="dataSource"/>
      <property name="packagesToScan" value="com.yanghj.ssh.entity"/>
      <property name="hibernateProperties">
          <props>
              <prop key="hibernate.hbm2ddl.auto">${hibernate.hbm2ddl.auto}</prop> <!--hibernate根据实体自动生成数据库表-->
              <prop key="hibernate.dialect">${hibernate.dialect}</prop>   <!--指定数据库方言-->
              <prop key="hibernate.show_sql">${hibernate.show_sql}</prop>     <!--在控制台显示执行的数据库操作语句-->
              <prop key="hibernate.format_sql">${hibernate.format_sql}</prop>     <!--在控制台显示执行的数据哭操作语句(格式)-->
          </props>
      </property>
  </bean>

  <!-- 事物管理器配置  -->
  <bean id="transactionManager" class="org.springframework.orm.hibernate4.HibernateTransactionManager">
      <property name="sessionFactory" ref="sessionFactory"/>
  </bean>

</beans>
复制

SpringMvc

<beans xmlns="http://www.springframework.org/schema/beans"
     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
     xmlns:context="http://www.springframework.org/schema/context"
     xmlns:mvc="http://www.springframework.org/schema/mvc"
     xsi:schemaLocation="http://www.springframework.org/schema/beans
      http://www.springframework.org/schema/beans/spring-beans-4.1.xsd
      http://www.springframework.org/schema/context
      http://www.springframework.org/schema/context/spring-context-4.1.xsd
      http://www.springframework.org/schema/mvc
      http://www.springframework.org/schema/mvc/spring-mvc-4.1.xsd">

  <!-- 启动注解驱动的spring MVC功能,注册请求url和注解POJO类方法的映射-->
  <mvc:annotation-driven/>

  <!--对@controller注解标注的bean进行自动扫描-->
  <context:component-scan base-package="com.yanghj.ssh.controller"/>

  <!-- 对模型视图名称的解析,在请求时模型视图名称添加前后缀 -->
  <bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
      <property name="viewClass" value="org.springframework.web.servlet.view.JstlView"/>
      <property name="prefix" value="views/"/>      <!-- 前缀 -->
      <property name="suffix" value=".jsp"/>   <!-- 后缀 -->
  </bean>

  <!--这里是对静态资源的映射-->
  <mvc:resources mapping="/js/**" location="/resources/js/"/>
  <mvc:resources mapping="/css/**" location="/resources/css/"/>
  <mvc:resources mapping="/img/**" location="/resources/img/"/>

</beans>
复制

最终效果

这是Hibernate自动生成的Sql语句哦,我们不需要编写!

浏览器效果

以上内容希望对大家有帮助,初学,希望大家多多指教!

END

关联标签: