Hibernate搭建成功!(源码)

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介:
昨天晚上搭建了我的第一个Hibernate框架。感觉挺爽的!

虽然两天还不会连接数据库,昨就把那么帅的东西搞出来了。

感觉很爽,Java真的很好,很强大。我学习Java才一个月左右,我还有许多需要学习的。

这次发的这个框架是Hibernate连接mysql。(所有代码均实际运行)

搭建环境:MyEclipse

下面是操作步骤:

1.在mysql中建立一个名为person的表。
表中数据:id varchar(32) no null primary key;
              name varchar(30) no null;
              password varchar(30) no null;
              sex varchar(2);
              email varchar(30);

2.打开MyEclipse,从菜单中选择窗口,选择首选项,选择数据库浏览器。

3.配置数据库驱动(mysql-connector-java-5.1.6-bin.jar)。

4.新建一个webproject,命名为HMWebproject,加入Add Hibernate Capabilities...,选择Hibernate3,Next---Finish

5. 选菜单的窗口,选择显示视图,选择其它,选MyEclipse中的DB Browser。点确定。从新窗口中选择New,连接数据库MySQL。

6.把数据库驱动放入此路径(例) D:\java\work\HMWebproject\WebRoot\WEB-INF\lib中,刷新列表,可以显示出新加入的包。

7.src下新建一个类(POJO类):包名为org.lxh.hibernate.demo,命名为Person,写入代码,最终显示如下:

package org.lxh.hibernate.demo;
//POJO类
public class Person {
         private String id;
         private String name;
         private String password;
         private String sex;
         private String email;
  public String getId() {
   return id;
  }
  public void setId(String id) {
   this.id = id;
  }
  public String getName() {
   return name;
  }
  public void setName(String name) {
   this.name = name;
  }
  public String getPassword() {
   return password;
  }
  public void setPassword(String password) {
   this.password = password;
  }
  public String getSex() {
   return sex;
  }
  public void setSex(String sex) {
   this.sex = sex;
  }
  public String getEmail() {
   return email;
  }
  public void setEmail(String email) {
   this.email = email;
  }
         
}

8.建立映射文件:点表person右键,选择Create Hibernate Mapping,创建在包org.lxh.hibernate.demo下,主键生成方式:assigned,完成。

9.修改映射文件:代码最终为--->

<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<!-- 
    Mapping file autogenerated by MyEclipse Persistence Tools
-->
<hibernate-mapping>
    <class name="org.lxh.hibernate.demo.Person" table="person" catalog="scutcs">
        <id name="id" type="java.lang.String">
            <column name="id" length="32" />
            <generator class="assigned" />
        </id>
        <property name="name" type="java.lang.String">
            <column name="name" length="20" not-null="true" />
        </property>
        <property name="password" type="java.lang.String">
            <column name="password" length="20" not-null="true" />
        </property>
        <property name="sex" type="java.lang.String">
            <column name="sex" length="2" />
        </property>
        <property name="email" type="java.lang.String">
            <column name="email" length="30" />
        </property>
    </class>
</hibernate-mapping>

9.在src下新建一个类:命名为PersonOperate,最终代码为----->

package org.lxh.hibernate.demo;

import java.util.List;

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

 

/*
 * 具体操作Hibernate的类
 * 增删改,按ID查询,模糊查询,查询全部
 */
public class PersonOperate {
  //Hibernate中所有操作都通过Session完成
  //此Session不同于JSP的Session
 private Session session=null;
 //构造方法中实现实例化Session对象
 public PersonOperate()
 {
 Configuration config=new Configuration().configure();
 //从配置中取得SessionFactory
 SessionFactory factory=config.buildSessionFactory();
 //SessionFactroy中取出一个Session
 this.session=factory.openSession();
 }
 //所有的操作都是通过Session进行的
 //向数据库中增加数据
 public void insert(Person p)
 {
   //开始事务
  
   Transaction tran =this.session.beginTransaction();
   
   //执行语句
   this.session.save(p);
   
   //提交事务
   tran.commit();
   //关闭Session
   this.session.close();
 }
 //修改
 public void update(Person p)
 {
  //开始事务
  Transaction tran =this.session.beginTransaction();
  //执行语句
  this.session.update(p);
  //提交事务
  tran.commit();
  this.session.close();
 }
 //按ID查询:推荐使用HQL
 public Person queryById(String id)
 {
  Person p=null;
  //使用Hibernate查询语言
  String hql="FROM Person as p WHERE p.id=?";
  //通过Query接口查询
  Query q=this.session.createQuery(hql);
  q.setString(0, id);
  List l=q.list();
  java.util.Iterator iter= l.iterator();
  if(iter.hasNext())
  {
   
  p=(Person)iter.next();
  }
  return p;
 }
    //删除数据
 //Hibernate2,Hibernate3通用的删除
 //使用此方法删除数据之前,必须先查找到数据对象
 public void delete(Person p)
 {
  Transaction tran=this.session.beginTransaction();
  //执行语句
  this.session.delete(p);
  //提交事务
  tran.commit();
  this.session.close();
  
 }
       //在Hibernate 3之中根据HQL中的语句进行了修改,增加了删除指令
      public void delete(String id)
      {
       String hql="DELETE Person WHERE id=?";
       Query q=this.session.createQuery(hql);
       //把参数设置
       q.setString(0, id);
       //执行更新语句
       q.executeUpdate();
       //进行事务处理
       this.session.beginTransaction().commit();
       this.session.close();
      }
        //查询全部数据,写HQL
      public List queryAll()
      {
       List l=null;
       String hql="FROM Person as p";
       Query q =this.session.createQuery(hql);
       l=q.list();
  return l;
       
      }
      //模糊查询
      public List queryByLike(String cond)
      {
       List l=null;
       String hql="FROM Person as p WHERE p.name like?";
       Query q =this.session.createQuery(hql);
       q.setString(0, "%"+cond+"%");
       l=q.list();
  return l;
       
      }
}


10.在src下新建插入类:命名为:TestPU
              新建更新类:命名为:TestPO
              新建删除类:命名为:TestPD
              新建HQL删除类:命名为:TestPD2
              新建按ID查询类:命名为:TestPI
              新建查询全部类:命名为:TestPK
              新建模糊查询类:命名为:TestPM
最终各类代码为----->

TestPU.java

package org.lxh.hibernate.demo;

public class TestPU {

 /**
  * @param args
  */
 public static void main(String[] args) {
  // TODO 自动生成方法存根
  //生成POJO类实例化对象
  Person p=new Person();
  p.setId("SNNN");
  p.setName("shiyangxt");
  p.setPassword("shiyang");
  p.setSex("女");
  p.setEmail("shiyangxt@126.com");
  PersonOperate po=new PersonOperate();
  po.insert(p);
 }
}

       

TestPO.java

package org.lxh.hibernate.demo;

public class TestPO {

 /**
  * @param args
  */
 public static void main(String[] args) {
  // TODO 自动生成方法存根
  //生成POJO类实例化对象
  Person p=new Person();
  p.setId("NNNN");
  p.setName("shiyangxt");
  p.setPassword("shiyang");
  p.setSex("女");
  p.setEmail("shiyangxt@126.com");
  PersonOperate po=new PersonOperate();
  po.update(p);

 }
    
}



TestPD.java

package org.lxh.hibernate.demo;

public class TestPD {

 /**
  * @param args
  */
 public static void main(String[] args) {
  // TODO Auto-generated method stub
      PersonOperate po=new PersonOperate();
      Person p=po.queryById("NNNN");
      po.delete(p);
 }

}



TestPD2.java

package org.lxh.hibernate.demo;

public class TestPD2 {

 /**
  * @param args
  */
 public static void main(String[] args) {
  // TODO 自动生成方法存根
  //生成POJO类实例化对象
  PersonOperate po=new PersonOperate();
  po.delete("SNNN");
       

 }

}



TestPI.java

package org.lxh.hibernate.demo;

public class TestPI {

 /**
  * @param args
  */
 public static void main(String[] args) {
  // TODO 自动生成方法存根
  //生成POJO类实例化对象
  PersonOperate po=new PersonOperate();
  Person p=po.queryById("NNNN");
        System.out.println(p.getName());

 }

}

TestPK.java

package org.lxh.hibernate.demo;

import java.util.Iterator;
import java.util.List;


public class TestPK {

 

 /**
  * @param args
  */
 public static void main(String[] args) {
  // TODO 自动生成方法存根
  //生成POJO类实例化对象
  PersonOperate po=new PersonOperate();
  List l=po.queryAll();
  Iterator iter= (Iterator) l.iterator();
  while(iter.hasNext())
  { 
   Person p = (Person)iter.next();
   System.out.println(p.getName());
  }


 }

}


TestPM.java

package org.lxh.hibernate.demo;

import java.util.Iterator;
import java.util.List;

public class TestPM {

 /**
  * @param args
  */
 public static void main(String[] args) {
  // TODO 自动生成方法存根
  //生成POJO类实例化对象
  PersonOperate po=new PersonOperate();
  List l=po.queryByLike("s");
  Iterator iter= (Iterator) l.iterator();
  while(iter.hasNext())
  { 
   Person p = (Person)iter.next();
   System.out.println(p.getName());
  }

 }

}

11.搭建完成!!!


本文转自施杨博客园博客,原文链接:http://www.cnblogs.com/shiyangxt/archive/2008/07/12/1241356.html,如需转载请自行联系原作者

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
6月前
|
XML Java 数据库连接
Spring Boot的数据访问之Spring Data JPA以及Hibernate的实战(超详细 附源码)
Spring Boot的数据访问之Spring Data JPA以及Hibernate的实战(超详细 附源码)
112 0
|
Java 关系型数据库 MySQL
兑现承诺,给粉丝专门搞了一个SpringBoot2.x整合hibernate5的教程,附带视频+源码,免费下载!
兑现承诺,给粉丝专门搞了一个SpringBoot2.x整合hibernate5的教程,附带视频+源码,免费下载!
109 0
|
6月前
|
SQL 缓存 Java
框架分析(9)-Hibernate
框架分析(9)-Hibernate
|
18天前
|
缓存 Java 数据库连接
Hibernate:Java持久层框架的高效应用
通过上述步骤,可以在Java项目中高效应用Hibernate框架,实现对关系数据库的透明持久化管理。Hibernate提供的强大功能和灵活配置,使得开发者能够专注于业务逻辑的实现,而不必过多关注底层数据库操作。
12 1
|
3月前
|
SQL Java 数据库连接
Hibernate 是一款开源 ORM(对象关系映射)框架,封装了 JDBC,允许以面向对象的方式操作数据库,简化了数据访问层的开发。
Hibernate 是一款开源 ORM(对象关系映射)框架,封装了 JDBC,允许以面向对象的方式操作数据库,简化了数据访问层的开发。通过映射机制,它可以自动处理对象与数据库表之间的转换,支持主流数据库,提高了代码的可移植性和可维护性。其核心接口包括 SessionFactory、Session 和 Transaction 等,通过它们可以执行数据库的 CRUD 操作。配置方面,需在项目中引入 Hibernate 及数据库驱动依赖,并创建 `hibernate.cfg.xml` 配置文件来设置数据库连接和 Hibernate 行为参数。
47 1
|
3月前
|
数据库 Java 数据库连接
Struts 2 与 Hibernate 的完美邂逅:如何无缝集成两大框架,轻松玩转高效 CRUD 操作?
【8月更文挑战第31天】本文通过具体示例介绍了如何在 Struts 2 中整合 Hibernate,实现基本的 CRUD 操作。首先创建 Maven 项目并添加相关依赖,接着配置 Hibernate 并定义实体类及其映射文件。然后创建 DAO 接口及实现类处理数据库操作,再通过 Struts 2 的 Action 类处理用户请求。最后配置 `struts.xml` 文件并创建 JSP 页面展示用户列表及编辑表单。此示例展示了如何配置和使用这两个框架,使代码更加模块化和可维护。
84 0