文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Hibernate如何使用

2024-04-02 19:55

关注

这篇文章主要介绍Hibernate如何使用,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

  hibernate的来源

  数据在各个层次之间流转,在流转过程中会发生数据类型转换等一系列的交互问题。java与html的交互解决方案是struts2提供的OGNL(对象导航图语言),而java与数据库之间的技术解决方案是ORM(对象关系映射)。

  什么是ORM

  对象关系映射:Object relation mapping

  1.对象:指的是java对象,是实体bean

  2.关系:关系只是数据库,sqlserver,mysql,oracle属于关系型数据库,操作关系型数据库用的是sql语言,但是sql有着明显的缺点,一次只能执行一条语句,没有什么基本的逻辑判断

  3.映射:java中对象的属性与数据库中的表字段之间一一对应(包含一对一,一对多,多对一,多对多)。

  ORM需要满足的条件

  有类属性和·表字段一一映射的关系

  将关系模型(数据库)的操作转化成对对象模型(pojo)的操作

  hibernate的优缺点

  好处:不要程序自己编写sql,简化了开发,提高了开发速度,hibernate入门门槛低,上手快。

  缺点:由hibernate自动生成的sql是标准的sql,优化难度大,失去了灵活性,对程序员要求较高,要懂一定的O/R映射。

  快速入手hibernate案列(maven)

  在pom.xml中导入相关的jar’包

  org.hibernate

  hibernate-core

  3.6.5.Final

  如果不能正常创建则需要导入其他包

  <--hibenate核心包-->

  org.hibernate

  hibernate-core

  3.6.8.Final

  <--单元测试包(可不导入)-->

  junit

  junit

  4.7

  test

  <-- Javassit其实就是一个二方包,提供了运行时操作Java字节码的方法-->

  org.javassist

  javassist

  3.13.0-GA

  <-- 并发访问处理端口的工具包。-->

  backport-util-concurrent

  backport-util-concurrent

  2.2

  <-- 日志文件包-->

  commons-logging

  commons-logging

  1.1.1

  <--纯Java的进程内缓存框架-->

  net.sf.ehcache

  ehcache

  1.2.3

  hibernate.cfg.xml配置文件

  "-//Hibernate/Hibernate Configuration DTD 3.0//EN"

  "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">

  oracle.jdbc.driver.OracleDriver

  jdbc:oracle:thin:@localhost:1521:orcl

  scott

  tiger

  none

  org.hibernate.dialect.Oracle10gDialect

  thread

  true

  3.*.xml映射文件

  先写一个实体bean

  package com.it.bean;

  public class Student {

  private String stu_id;

  private String stu_name;

  private String stu_sex;

  private String stu_birth;

  private String stu_addr;

  public String getStu_id() {

  return stu_id;

  }

  public void setStu_id(String stu_id) {

  this.stu_id = stu_id;

  }

  public String getStu_name() {

  return stu_name;

  }

  public void setStu_name(String stu_name) {

  this.stu_name = stu_name;

  }

  public String getStu_sex() {

  return stu_sex;

  }

  public void setStu_sex(String stu_sex) {

  this.stu_sex = stu_sex;

  }

  public String getStu_birth() {

  return stu_birth;

  }

  public void setStu_birth(String stu_birth) {

  this.stu_birth = stu_birth;

  }

  public String getStu_addr() {

  return stu_addr;

  }

  public void setStu_addr(String stu_addr) {

  this.stu_addr = stu_addr;

  }

  public Student(String stu_id, String stu_name, String stu_sex, String stu_birth, String stu_addr) {

  super();

  this.stu_id = stu_id;

  this.stu_name = stu_name;

  this.stu_sex = stu_sex;

  this.stu_birth = stu_birth;

  this.stu_addr = stu_addr;

  }

  public Student() {

  super();

  // TODO Auto-generated constructor stub

  }

  public Student(String stu_id, String stu_name) {

  super();

  this.stu_id = stu_id;

  this.stu_name = stu_name;

  }

  }

  与之对应的映射文件

  "-//Hibernate/Hibernate Mapping DTD 3.0//EN"

  "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">

  dao层的书写

  BaseDao

  package com.it.dao;

  import java.util.List;

  import org.hibernate.Query;

  import org.hibernate.Session;

  public class BaseDao{

  private Session session;

  public BaseDao(Session session){

  this.session=session;

  }

  public void add(E e){

  session.save(e);

  }

  public void delete(E e){

  session.delete(e);

  }

  public void update(E e){

  session.update(e);

  }

  public List finbBySplit(int currentPage,int currentSize,String hql,String...params){

  Query query=session.createQuery(hql);

  //给问号占位符赋值

  for (int i = 0; i < params.length; i++) {

  query.setString(i, params[i]);

  }

  //分页参数

  int first=(currentPage-1)*currentSize;

  query.setFirstResult(first);

  query.setMaxResults(currentSize);

  //查询

  return query.list();

  }

  }

  StudentDao层的书写

  package com.it.dao;

  import java.util.List;

  import org.hibernate.Session;

  import com.it.bean.Student;

  public class StudentDao extends BaseDao{

  public StudentDao(Session session) {

  super(session);

  // TODO Auto-generated constructor stub

  }

  public void add(Student stu){

  super.add(stu);

  }

  public void delete(Student stu){

  super.delete(stu);

  }

  public void update(Student stu){

  super.update(stu);

  }

  public List find(int currentPage,int currentSize,Student stu){

  String hql="from Student stu where stu.stu_id like ? and stu.stu_name like ? and stu.stu_sex like ? and stu.stu_birth like ? and stu.stu_addr like ? ";

  String []params={"%"+stu.getStu_id()+"%","%"+stu.getStu_name()+"%","%"+stu.getStu_sex()+"%","%"+stu.getStu_birth()+"%","%"+stu.getStu_addr()+"%"};

  return super.finbBySplit(currentPage, currentSize, hql, params);

  }

  }

  此时便可测试了

  @Test

  public void add(){

  SessionFactory sessionFactory=null;

  Session session=null;

  Transaction tx=null;

  try {

  //创建sessionfactory

  sessionFactory=new Configuration().configure().buildSessionFactory();

  //创建session回话---得到线程本身的回话

  session=sessionFactory.getCurrentSession();

  //开启事务

  tx=session.beginTransaction();

  //添加数据

  Student stu=new Student("0000","沈浪","男","87","北京");

  // session.save(stu);

  //修改数据

  // stu.setStu_name("沈万三");

  // session.update(stu);

  //删除数据

  // session.delete(stu);

  //提交事务

  //按照id查询一条数据

  // Student stu1=(Student)session.get(Student.class, "0000");

  // System.out.println(stu1.getStu_name());

  //hql的使用

  //查询所有信息

  无锡×××医院 https://yyk.familydoctor.com.cn/20612/

  //返回vo对象

  

  //返回map类型的参数

  

  //占位符? :

  

  //:占位符

  

  //返回number类型的参数

  

  //模糊搜素

  

  //hibernate分页

  String hql="from Student where stu_id like '%2%'";

  Query query=session.createQuery(hql);

  int currentPage=1;

  int pageSize=4;

  int startPage=(currentPage-1)*pageSize;

  query.setFirstResult(startPage); //开始显示的位置

  query.setMaxResults(pageSize); //显示最大数据数

  System.out.println(query.list().size());

  tx.commit();

  } catch (Exception e) {

  // TODO: handle exception

  e.printStackTrace();

  //事务回滚

  tx.rollback();

  }

  }

  此刻一个简单的demo变创建成功了

以上是“Hibernate如何使用”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注亿速云行业资讯频道!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯