Hibernate学习框架:
1、基本部分

     crud的操作

     主键的生成机制

     类型

     持久化类

     映射文件 *.hbm.xml

     配置文件 hibernate.cfg.xml

2、关系部分

     一对多的单项

     一对多的双向

     多对多的双向

     一对一

        在many-to-one加一个属性unique="true"

        cascade  级联
        inverse  维护关系  <set>中lazy,fetch

3、性能的部分

  • 维护关系 inverse
  • 懒载入 lazy
  • 抓取策略 fetch
  • 一级缓存
  • 二级缓存

查询缓存

4、查询

    hql

    条件查询



一。Hibernate概述:
在servlet中。操作数据库我们使用的是jdbc,为了更加方便的操作数据库,我们能够使用ORM框架,ORM:Object Relation Mapping,对象关系映射。目的就是像操作java普通的类一样来操作数据库。

显然Hibernate是ORM框架中做得比較好的一款!


Hibernate的有点:
  • 面向对象数据库编程;
  • 代码书写更加简洁;
  • 具有缓存机制。提高效率;

二.入门:

准备条件:

1.导入相关的包
2.hibernate.cfg.xml:(通常位于scr根文件夹下)
数据库要自己先新建好。!
<?xml version= '1.0' encoding ='utf-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
        "-//Hibernate/Hibernate
Configuration DTD 3.0//EN"
        "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd" >

<hibernate-configuration>
     <session-factory >
           <!-- 数据库的username
-->
           <property name="connection.username" >root </property>
           <!-- password -->
           <property name="connection.password" >root </property>
           <!-- url -->
           <property name= "connection.url">
              jdbc:mysql:// localhost:3306/hibernate512
           </property>
           <!-- 方言 告诉hibernate,要操作的数据库是mysql -->
           <property name="dialect" >org.hibernate.dialect.MySQLDialect </property>
           <!-- 导入驱动 -->
           <property name= "connection.driver_class" >
              com.mysql.jdbc.Driver
           </property>
     
           <!-- validate
仅仅检查结构 update 检查结构,更新或者创建表 create 每次启动 hibernate时,都要创建表 create-drop
              启动 hibernate时创建表。当 hibernate关闭时,删除表
-->
           <property name= "hbm2ddl.auto">update</property >
           <!--显示sql语句的输出 
-->
           <property name= "show_sql"> true</ property >
            <property name= "format_sql"> true</ property >
          
           <!--关联映射文件,手动加入。然后自己主动生成。 
-->
           <mapping resource="com/oteman/hibernate/domain/Person.hbm.xml" />
     
     </session-factory >

</hibernate-configuration>

3.要操作的实体bean(Person为例)
package com.oteman.hibernate.domain;

public class Person
{
     Long pid;
     String pname;
     String pgender;
     public Long
getPid() {
           return pid ;
     }
     public void setPid(Long
pid) {
           this.pid =
pid;
     }
     public String
getPname() {
           return pname ;
     }
     public void setPname(String
pname) {
           this.pname =
pname;
     }
     public String
getPgender() {
           return pgender ;
     }
     public void setPgender(String
pgender) {
           this.pgender =
pgender;
     }

}


4.要操作的实体与数据库表的相应关系Person.hbm.xml
(通常与实体bean在同一个文件夹)
<?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" >

<!-- 数据库表和类之间的映射关系  字段和表列名之间的关系 -->
<hibernate-mapping>
     <class name="com.oteman.hibernate.domain.Person"  table="Person" >
           <id name= "pid" column ="pid" length="5" type="java.lang.Long" >
               <generator class= "increment"></generator >
           </id>
           <property name= "pgender" column ="gender" length="10" type="string"></ property>
           <property name= "pname" column ="name" length="20" ></property>
     </class >

</hibernate-mapping>


5.依据配置文件建立表
     @Test
     public void testCreateTable(){
          Configuration configuration= new Configuration();
          configuration.configure();
          SessionFactory sessionFactory = configuration.buildSessionFactory();
     }


6.增删改查:
/**
      * 向数据库中添加数据
      */
     @Test
     public void add(){

          Session session = sessionFactory.openSession();
          Transaction transaction = session.beginTransaction();
          Person p= new Person();
          p.setPgender( "男");
          p.setPname( "张三");
          session.save(p);
          transaction.commit();
          session.close();
     }
     
     /**
      * 更新数据, hibernate具有快照机制,会将对象前后的值进行比較,假设发现对象的属性没有发生改变,那么就不进行update操作,能够观察 sql语句;
      */
     @Test
     public void update(){
          Session session = sessionFactory.openSession();
          Transaction transaction = session.beginTransaction();
          Person person=(Person) session.get(Person. class,
2l);
          person.setPname( "哈哈");
           /*//另外一种形式:
          Person p=new Person();
          p.setPgender("男");
          p.setPid(2L);
          p.setPname("李四");*/
          session.update(person);
          transaction.commit();
          session.close();
     }
     /**
      * 删除数据
      */
     @Test
     public void delete(){
          Session session= sessionFactory.openSession();
          Transaction transaction = session.beginTransaction();
          Person person=(Person) session.get(Person. class,
1l);
          session.delete(person);
          
          transaction.commit();
          session.close();
          
     }
     /**
      * 查询全部!

      */
     @Test
     public void query(){
          Session session= sessionFactory.openSession();
           List list = session.createQuery("from
Person").list();
          System. out.println(list.size());
          session.close();
     }

7.Generator主键产生机制
public class GeneratroTest extends HibernateUtils{
     
     /**
      *
      * 1.<id name=" pid" column="pid"
type="java.lang.Long">
               <generator class="increment"> </generator>
           </id>
      * increament形式产生的 sql语句
      *    Hibernate:
              select
                  max( pid)
              from
                  person
           Hibernate:
              insert
              into
                  person
                  ( pname, psex , pid)
              values
                  (?, ?

, ?)

                 
           说明:
              1、先得到主键的最大值
              2、在最大值的基础上加1
              3、上述的两步过程是由 hibernate内部完毕的
      */
     @Test
     public void testIncrement(){
          Session session =  sessionFactory.openSession();
          Transaction transaction = session.beginTransaction();
          Person person = new Person();
           //person.setPid(11L);为increament时,自行设置的id没实用, hibernate会帮我们处理id;
          person.setPname( "云三班长" );
          person.setPsex( "不详");
          session.save(person);
          transaction.commit();
          session.close();
     }
     
     /**
      *
      * 2.<generator class="identity"> </generator>
      *
      * Hibernate:
         insert
         into
             person
             ( pname, psex )
         values
             (?, ?)
             说明:
               主键的生成交给数据库来做,数据库必须支持自己主动增长机制,会出现id不连续的情况,效率比increment要高一些;
      */
     @Test
     public void testIdentity(){
          Session session =  sessionFactory.openSession();
          Transaction transaction = session.beginTransaction();
          Person person = new Person();
           //person.setPid(11L);
          person.setPname( "云三班长" );
          person.setPsex( "不详");
          session.save(person);
          transaction.commit();
          session.close();
     }
     
     /**
      * 3.<generator class=" uuid"></generator>
      * 主键的生成是由 hibernate内部完毕的
      */
     @Test
     public void testUUID(){
          Session session =  sessionFactory.openSession();
          Transaction transaction = session.beginTransaction();
          Person person = new Person();
          person.setPname( "云三班长" );
          person.setPsex( "不详");
          session.save(person);
          transaction.commit();
          session.close();
     }
     /**
      * 4.<generator class="assign"> </generator>
      * 主键的生成由自己指定。
      */
     @Test
     public void testAssigned(){
          Session session =  sessionFactory.openSession();
          Transaction transaction = session.beginTransaction();
          Person person = new Person();
          person.setPid(11L);
          person.setPname( "云三班长" );
          person.setPsex( "不详");
          session.save(person);
          transaction.commit();
          session.close();
     }
}

【Hibernate一】概述及入门的更多相关文章

  1. 一起学习Hibernate: Hibernate01 —— Hibernate的概述与入门案例

    一 Hibernate的介绍 1 让我们从JDBC与替代它的框架Hibernate进行一下对比. 1.1 JDBC的缺点 1) 代码结构繁琐.每次书写sql语句操作数据库都得需要很多步; 2) 是面向 ...

  2. 三大框架 之 Hibernate框架概述(概述、配置、核心API)

    目录 Hibernate框架概述 什么是框架 hibernate简介(JavaEE技术三层架构所用到的技术) hibernate是什么框架 ORM hibernate好处 Hibernate基本使用 ...

  3. MySql概述及入门(五)

    MySql概述及入门(五) MySQL集群搭建之读写分离 读写分离的理解 为解决单数据库节点在高并发.高压力情况下出现的性能瓶颈问题,读写分离的特性包括会话不开启事务,读语句直接发送到 salve 执 ...

  4. MySQL概述及入门(四)

    MySql概述及入门(四) 什么是MySQL的锁? 数据库锁定机制,就是数据库为了保证数据的一致性,而使各种共享资源在被并发访问变得有序所设计的一种规则,简单说,就是不让别人动 总的来说,MySQL各 ...

  5. MySQL概述及入门(三)

    MySql概述及入门(三) MySQL性能优化 主要优化安全和性能方面 安全方面 : 数据可持续性 性能方面 : 数据的高性能访问 性能优化——慢查询 在MySQL数据库中有一个慢查询日志功能,去获取 ...

  6. MySQL概述及入门(二)

    MySql概述及入门(二) MySQL架构 逻辑架构图: 执行流程图: MySQL的存储引擎 查询数据库支持的存储引擎 执行: show engines: 多存储引擎是mysql有别于其他数据库的一大 ...

  7. MySQL概述及入门(一)

    MySql概述及入门(一) 什么是MySQL?    MySQL是当今主流的关系型数据库管理系统(记录是有行有列的数据库) , 可以与Oracle 和SQL Server 竞争 , 是最好RDBMS( ...

  8. Hibernate学习笔记(一)—— Hibernate概述及入门

    一.Hibernatea概述 1.1 什么是Hibernate? 在介绍什么是Hibernate之前,我们先讨论一下什么是框架?框架是用来提高开发效率的,框架封装好了一些功能,我们需要使用这些功能时, ...

  9. Hibernate_day01--课程安排_Hibernate概述_Hibernate入门

    Hibernate_day01 Hibernate课程安排 今天内容介绍 WEB内容回顾 JavaEE三层结构 MVC思想 Hibernate概述 什么是框架 什么是hibernate框架(重点) 什 ...

随机推荐

  1. 克鲁斯卡尔(并查集)hdu 1233

    还是畅通工程 Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Sub ...

  2. java8新特性——简介

    java8问世已经有好长时间了,但是之前项目中都没有使用到,所以一直都只是了解一些,近期刚刚换了家新公司,在开发中需要使用到java8来开发,所以也是马上赶来学习一下java8得新特性. 一.新特性 ...

  3. NOIP2018提高组题解

    D1T1:铺设道路 回忆NOIP2013D2T1 积木大赛,发现这两题唯一的区别就是一个是造山一个是填坑,而把填坑的操作反序就是造山,所以可以直接使用那道题的方法. 具体方法是,从左到右每次考虑新的一 ...

  4. CodeForces - 1009D Relatively Prime Graph

    题面在这里! 直接暴力找点对就行了,可以证明gcd=1是比较密集的,所以复杂度略大于 O(N log N) #include<bits/stdc++.h> #define ll long ...

  5. 【最大化平均值】POJ3111-K Best

    [题目大意] 给出v[]和w[],求的最大值. [思路] 二分s(S)的值,可变形为s(S)*Σw>=Σv,所以只需要把求出x*w[i]-v[i],看看前k个的和是否大于等于0,大于等于0就满足 ...

  6. 让你的chrome开发工具console支持jquery

    首先执行以下代码: ;(function(d,s){d.body.appendChild(s=d.createElement('script')).src='http://code.jquery.co ...

  7. 设计模式 -- 桥接模式(Bridge)

    写在前面的话:读书破万卷,编码如有神--------------------------------------------------------------------主要内容包括: 初始桥接模式 ...

  8. UESTC 2015dp专题 F 邱老师看电影 概率dp

    邱老师看电影 Time Limit: 20 Sec  Memory Limit: 256 MB 题目连接 http://acm.uestc.edu.cn/#/contest/show/65 Descr ...

  9. vscode 插件设置

    VS Code 安装插件 prettier Beautify vscode 首选项 --> 设置 "editor.detectIndentation": false, &qu ...

  10. Ubuntu 16.09下iptables通过raw表实现日志输出和调试

    1.先配置好raw表日志打点功能 参考:http://www.cnblogs.com/EasonJim/p/8413563.html 2.配置好messages文件 参考:http://www.cnb ...