mio4 Java Web & Web Security

Hibernate(1):入门

2018-10-23
mio4

阅读:


(一)Hibernate

(1)初识Hibernate

  • Hibernate
    • JavaEE应用的持久层框架(轻量级)
    • 是一个全自动的ORM框架(Object Relative Database Mapping)
      • ORM:通过操作JavaBean对象达到操作数据库的效果
  • 为什么要使用Hibernate
    • 对JDBC访问数据库的操作进行了封装,简化了Dao层的编码
  • 使用步骤
    • 导入jar包
    • 创建数据库和表
    • 核心配置文件hibernate.cfg.xml
    • JavaBean映射文件xx.hbm.xml
  • IDEA下创建Hibernate项目
    • Web Application和Hibernate,勾选Create default hibernate configuration and main class
    • 在lib下导入mysql-connector.jar包以及log4j日志包
    • Project Structure -> Module中导入lib下的所有包(防止com.mysql.jdbc.Driver报错)

(2)配置文件

(1)JavaBean映射

<?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="com.mio4.domain.Customer" table="cst_customer">
        <!--
            name:JavaBean的属性
            column:表结构字段
        -->
        <id name="cust_id" column="cust_id">
            <!-- 主键生成策略 -->
            <generator class="native"/>
        </id>

        <!--配置其他的属性-->
        <property name="cust_name" column="cust_name"/>
        <property name="cust_user_id" column="cust_user_id"/>
        <property name="cust_create_id" column="cust_create_id"/>
        <property name="cust_source" column="cust_source"/>
        <property name="cust_industry" column="cust_industry"/>
        <property name="cust_level" column="cust_level"/>
        <property name="cust_linkman" column="cust_linkman"/>
        <property name="cust_phone" column="cust_phone"/>
        <property name="cust_mobile" column="cust_mobile"/>

    </class>
</hibernate-mapping>

(2)Hibernate配置

  • hibernate.cfg.xml配置文件,针对MySQL
<?xml version='1.0' encoding='utf-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
        "-//Hibernate/Hibernate Configuration DTD//EN"
        "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
    <session-factory>
        <!--连接MySQL数据库:必须配置-->
        <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
        <property name="hibernate.connection.url">jdbc:mysql://localhost:3306/hibernate_day01</property>
        <property name="hibernate.connection.username">root</property>
        <property name="hibernate.connection.password">123456</property>

        <!--数据库方言:必须配置-->
        <property name="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</property>

        <!--映射配置文件:必须配置-->
        <mapping resource="com/mio4/domain/Customer.hbm.xml"/>

    </session-factory>
</hibernate-configuration>

过程中报错:org.hibernate.service.spi.ServiceException: Unable to create requested service [org.hibernate.engine.jdbc.env.spi.JdbcEnvironment],一般是hibernate.cfg.xml中JDBC四个参数出错,特别注意hibernate.connection.url

  • 配置可选项
        <!--在控制台显示SQL语句-->
        <property name="hibernate.show_sql">true</property>
        <!--格式化SQL语句-->
        <property name="hibernate.format_sql">true</property>
        <!--每次创建一张新表,然后再进行数据库操作-->
        <!--<property name="hibernate.hbm2ddl.auto">create</property>-->

        <!--如果没有表则创建表,其他情况正常操作-->
        <property name="hibernate.hbm2ddl.auto">update</property>

(3)数据库交互

  • 一个简单的向数据库中添加一条数据的操作
		//1.加载配置文件
		Configuration config = new Configuration();
		config.configure(); //默认加载src下的hibernate.cfg.xml文件
		//2.创建SessionFactory对象
		SessionFactory factory = config.buildSessionFactory();
		//3.创建Session对象
		Session session = factory.openSession();
		//4.开启事务
		Transaction transaction = session.beginTransaction();
		//5.编写保存代码
		Customer customer = new Customer();
		customer.setCust_name("test_name2");
		customer.setCust_level("1");
		session.save(customer);
		//6.提交事务
		transaction.commit();
		//7.释放资源
		session.close();

(1)Session

  • session的作用是执行持久化对象的CRUD操作
    • 此Session不同于HttpSession中的会话技术,而是Java程序和数据库的一次交互
    • session不是线程安全的,使用session之后需要session.close()释放资源
  • session主要方法
    • save(JavaBean对象) 保存数据
    • get(JavaBean.class,主键) 查询数据
    • delete(JavaBean对象):(需要是先查询出来的的对象) 删除数据
    • saveOrUpdate(JavaBean对象)
    • create Query(“from JavaBean对象”) 查询所有的对象,返回list集合

(2)Transaction

  • 参考事务,主要方法
    • commit() 事务提交
    • rollback() 事务回滚

Comments

Content