Hibernate相关使用

1 创建一个maven项目,在pom.xml文件中添加相关依赖

 <dependencies>
        <dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-core</artifactId>
            <version>3.6.10.Final</version>
        </dependency>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.26</version>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>1.18.6</version>
        </dependency>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.13.2</version>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>log4j</groupId>
            <artifactId>log4j</artifactId>
            <version>1.2.17</version>
        </dependency>
        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-nop</artifactId>
            <version>1.6.4</version>
        </dependency>
        <dependency>
            <groupId>org.javassist</groupId>
            <artifactId>javassist</artifactId>
            <version>3.21.0-GA</version>
        </dependency>
    </dependencies>

2 创建与数据表,我的数据库是mytest,表名是student

在这里插入图片描述

3 创建与数据库表对应的实体类

package com.it.pojo;

import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.ToString;

@Data  //提供属性的getter和setter方法
@ToString
@AllArgsConstructor //全参数构造器
@NoArgsConstructor  //空参构造器
public class Student {
    private String sid;
    private String name ;
    private String class1;
}

4 配置实体类与数据库表的映射关系

  • 创建Student.hbn.xml文件
<!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.it.pojo.Student" table="student">
        <id name="sid" column="sid">
<!--            指定主键生成机制-->
            <generator class="uuid"></generator>
        </id>
        <property name="name" column="name"/>
        <property name="class1" column="class"/>

    </class>
</hibernate-mapping>

5 配置hibernate核心配置文件

  • 创建文件hibernate.cfg.xml
<!DOCTYPE hibernate-configuration  PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
        "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory>
<!--    配置数据库信息-->
    <property name="hibernate.connection.driver_class">com.mysql.cj.jdbc.Driver</property>
    <property name="hibernate.connection.url">jdbc:mysql:///mytest</property>
    <property name="hibernate.connection.username">root</property>
    <property name="hibernate.connection.password">123456</property>
<!--控制台打印SQL语句    -->
    <property name="hibernate.show_sql">true</property>
<!--    输出底层SQL格式-->
    <property name="hibernate.format_sql">true</property>
<!--  hibernate帮创建表,需要配置之后 update: 如果已经有表,更新,如果没有,创建  -->
    <property name="hibernate.hbm2ddl.auto">update</property>
<!-- 配置数据库方言在mysql里面实现分页 关键字 limit,只能使用mysql里面在oracle数据库,实现分页rownum 让hibernate框架识别不同数据库的自己特有的语句   -->
    <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
<!--    映射文件-->
    <mapping resource="mapping/Student.hbn.xml"/>
</session-factory>
</hibernate-configuration>

6 工具类

package com.it.util;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;

public class HibernateUtil {
    private static SessionFactory factory;

    public static Session getFactory() {
        factory = new Configuration().configure().buildSessionFactory();
        Session session = factory.openSession();
        return session;
    }

}

7创建数据操作类

package com.it.dao;

import com.it.pojo.Student;
import com.it.util.HibernateUtil;
import org.hibernate.HibernateException;
import org.hibernate.Session;
import org.hibernate.Transaction;

import java.util.Iterator;
import java.util.List;
public class StudentDao {
    /**
     * 查询全部
     */
    public void findAll(){
        Session session = HibernateUtil.getFactory();
        Transaction tx = null;
        try {
            tx = session.beginTransaction();
            List list = session.createQuery("FROM Student ").list();
            for (Iterator iterator = list.iterator(); iterator.hasNext();) {
                Student tmp = (Student) iterator.next();
                System.out.println(tmp.getName());
            }
            tx.commit();
        } catch (HibernateException e) {
            if (tx != null)
                tx.rollback();
            e.printStackTrace();
        } finally {
            session.close();
        }
    }

    /**
     * 新增数据
     * @return
     */
    public Integer save(){
        Transaction tx = null;
        Student student = new Student("","dadd","aaa");
        Session session = HibernateUtil.getFactory();
        try {
             tx = session.beginTransaction();
            Object save = session.save(student);
            tx.commit();
            System.out.println(save.toString());
            System.out.println("插入数据成功...");
        }catch (HibernateException e){
            if (tx!=null){
                tx.rollback();
            }
        }finally {
            session.close();
        }
        return 1;
    }
    public void delete(){
        Student student = new Student("","dadd","aaa");
        Transaction tx = null;
        Session session = HibernateUtil.getFactory();
        try {
            tx =session.beginTransaction();
            Query query = session.createQuery("delete from Student where name=:name");
            query.setString("name",student.getName());
            query.executeUpdate();
            tx.commit();
            System.out.println("删除成功...");

        }catch (HibernateException e){
            if (tx!=null){
                tx.rollback();
                System.out.println("删除失败");
              
            }
        }finally {
            session.close();
            System.out.println("结束运行");
        }
    }

    /**
     * 测试
     * @param args
     * @throws Exception
     */
    public static void main(String[] args) throws Exception {
        StudentDao studentDao = new StudentDao();
        //调用新增数据方法
        //studentDao.save();
        //调用查询所有方法
//        studentDao.findAll();
//删除
studentDao.delete();
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值