首先要导入包,将下载的hibernate所有required包导入,将下载的hibernate用来写log的slf4j的api和nopjar包导入,将下载的mysql链接引擎jar包导入。

然后新建java工程。

先告诉hiernate怎么连数据库:在hibernate默认识别目录src根目录下以默认hibernate配置文件名hibernate.cfg.xml建立xml(都采用默认可以省去在代码中书写路径和名字的麻烦):

<?xml version='1.0' encoding='utf-8'?>
<!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>

<!-- Database connection settings -->
        <property name="connection.driver_class">com.mysql.jdbc.Driver</property>
        <property name="connection.url">jdbc:mysql://localhost:3306/hibernate</property>
        <property name="connection.username">root</property>
        <property name="connection.password">mysql</property>

<!--
        <property name="connection.driver_class">oracle.jdbc.driver.OracleDriver</property>
        <property name="connection.url">jdbc:oracle:thin:@localhost:1521:SXT</property>
        <property name="connection.username">scott</property>
        <property name="connection.password">tiger</property>
       <property name="dialect">org.hibernate.dialect.OracleDialect</property>
       -->

<!-- JDBC connection pool (use the built-in) -->
     <!--    <property name="connection.pool_size">1</property> 数据库连接池大小 -->

<!-- SQL dialect sql语句方言-->
        <property name="dialect">org.hibernate.dialect.MySQLDialect</property>

<!-- Enable Hibernate's automatic session context management -->
<!--         <property name="current_session_context_class">thread</property>

      指定getCurrentSession的上下文,如果不指定只能用openSession。有thread(当前线程),jta,managed(jee、EJB中使用applicationserver,且要手工管理currentSession手工管理事务的时候要用该值),custom.class(自定义class管理currentSession)

      jta:java transaction api,java中一种用于管理事务的api,和实现了该api的应用服务器的JTATransactionManager结合使用可以处理分布存储。

-->
        <!-- Disable the second-level cache  -->
        <property name="cache.provider_class">org.hibernate.cache.internal.NoCacheProvider</property>

<!-- Echo all executed SQL to stdout -->
        <property name="show_sql">true</property>

<property name="format _sql">true</property>

<!-- Drop and re-create the database schema on startup -->
<!--         <property name="hbm2ddl.auto">update</property>
-->
        <mapping resource="com/test/hibernate/model/Student.hbm.xml"/>

<mapping class="com.test.hibernate.model.Teacher"/>

</session-factory>

</hibernate-configuration>

然后告诉hibernate数据库和model的映射关系,也采用默认目录和命名方式:

在model(这里是Student类)所在目录下新建Student.hbm.xml,名字要和类名一致,对于Teacher类,因为使用了注解所以不需要,也可以看出来使用注解相对来说比较方便。

配置文件中如果表名和类名不一致也可以指定表名,参见本文末尾处的一段配置

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
        "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
        "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">

<hibernate-mapping package="com.test.hibernate.model">
    <class name="Student">
        <id name="id"></id>
        <property name="name"></property>
        <property name="age"></property>
    </class>
</hibernate-mapping>

数据库也一致,只有三列,其中id是主键。

指定id生成策略示例代码:

<id name="id">

<generator class="uuid"></generator>

<!-- 指定数据库该主键生成策略为uuid,uuid要求主键必须是个字符串才能采用,uuid全局唯一id。指定生成策略后就不需要手动设置主键了。

还可以设成:native,int型,会根据数据库本地自动生成。

关于生成策略更多内容参见hibernate API "5.1.2.2.1. Various additional generators" -->

</id>

Student类:

package com.test.hibernate.model;

public class Student {
    private int id;
    private String name;
    private int age;
   
    public int getId() {
        return id;
    }
    public void setId(int id) {
        this.id = id;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public int getAge() {
        return age;
    }
    public void setAge(int age) {
        this.age = age;
    }

}

Teacher类:

package com.test.hibernate.model;

import javax.persistence.*;

import java.util.Date;

@Entity   //实体类 表示和数据库内容一一对应,无需额外书写映射关系xml
//@Table(name = “_Teacher”) 如果表名和类名不一致(不区分大小写),可以用这个注解来标明表名

public class Teacher {
    private int id;
    private String name;
    private String title;

private Date birthDate;
    
    @Id  //主键

    //@Basic //对于和数据对应的字段可以写,相当于加了

public int getId() {
        return id;
    }

public void setId(int id) {
        this.id = id;
    }

@Column(name=”_name”)//字段名和属性名不对应时可以这样指定对应的属性名
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }

//如果不想往数据库中存放,可以加个注解,透明的—@Transient

public String getTitle() {
        return title;
    }
    public void setTitle(String title) {
        this.title = title;
    }

//可以只保存录入时间的日期部分或者时间部分@Temporal(TemporalType.DATE),这样数据库中就会用DATE类型来保存数据,默认是DATETIME,日期时间一起保存

public Date getBirthDate(){

return birthDate;

}

public void setBirthDate(Date birthDate){

this.birthDate=birthDate;

}
}

关于用注解的方式指定主键生成策略:

@GeneratedValue  默认策略AUTO,相当于xml中的native,会使数据库根据本地策略自动生成,如果是mysql会auto increament,如果是oracle则sequence。

@GeneratedValue(strategy = GenerationType.IDENTITY)

@GeneratedValue(strategy = GenerationType.SEQUENCE)

@SequenceGenerator(name="thissequencegeneratorname",sequenceName="aa")定义一个generator前者是它自己的名字,后者是它采用的数据库中的生成器的名字,定义要写在@Entity下面,类上面。下面这一行是采用该generator

@GeneratedValue(strategy = GenerationType.SEQUENCE,generator="thissequencegeneratorname")

@Entity
@javax.persistence.TableGenerator(
     name="Teacher_GEN",
     table="GENERATOR_TABLE",
     pkColumnName = "pk_key",
     valueColumnName = "pk_value",
     pkColumnValue="Teacher",
     allocationSize=1
 )//表生成器,可以跨数据库平台

@Id
 @GeneratedValue(strategy=GenerationType.TABLE, generator="Teacher_GEN")
 public int getId() {
  return id;
 }

然后就可以写测试类了:

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;
import org.hibernate.service.ServiceRegistry;
import org.hibernate.service.ServiceRegistryBuilder;

import com.test.hibernate.model.Student;

public class StudentTest {
    public static void main(String args[]){
        Student s = new Student();
        s.setId(1);
        s.setName("s2");
        s.setAge(1);
       
        Configuration cfg = new Configuration();
       
        //SessionFactory sf = cfg.configure().buildSessionFactory();
       
        cfg.configure();//解析所有hibernate的配置xml,不指定参数就会去找默认目录下的xml
        ServiceRegistry  sr = new ServiceRegistryBuilder().applySettings(cfg.getProperties()).buildServiceRegistry();
        SessionFactory sf = cfg.buildSessionFactory(sr);//生成session工厂,相当于产生数据库连connection的工厂
       
        Session session = sf.openSession();//相当于数据库的一个connection
        session.beginTransaction();
        //session.save(s);
        //session.delete(s);
        session.update(s);
        session.getTransaction().commit();
        session.close();//关闭connection
        sf.close();//关闭工厂相当于关闭了数据连接池
    }

}

import org.hibernate.Session;
import org.hibernate.SessionFactory;
//import org.hibernate.cfg.AnnotationConfiguration;过时了,该类的所有内容都已经被包含在Configuration类中。
import org.hibernate.cfg.Configuration;
import org.hibernate.service.ServiceRegistry;
import org.hibernate.service.ServiceRegistryBuilder;

import com.test.hibernate.model.Teacher;

public class TeacherTest {
    public static void main(String args[]){
        Teacher t = new Teacher();
        t.setId(2);
        t.setName("t3");
        t.setTitle("中级");
       
        //Configuration cfg = new AnnotationConfiguration();
        Configuration cfg = new Configuration();
       
        //SessionFactory sf = cfg.configure().buildSessionFactory();
       
        cfg.configure();//解析所有hibernate的配置xml,不指定参数就会去找默认目录下的xml
        ServiceRegistry  sr = new ServiceRegistryBuilder().applySettings(cfg.getProperties()).buildServiceRegistry();
        SessionFactory sf = cfg.buildSessionFactory(sr);//生成session工厂,相当于产生数据库连connection的工厂
       
        Session session = sf.openSession();//相当于数据库的一个connection
        session.beginTransaction();
        session.save(t);
        session.getTransaction().commit();
        session.close();//关闭connection
        sf.close();//关闭工厂相当于关闭了数据连接池
    }

}

class配置参考例子:

<class

name="ClassName"

table="tableName"

discriminator-value="discriminator_value"

mutable="true|false"

schema="owner"

catalog="catalog"

proxy="ProxyInterface"

dynamic-update="true|false"

dynamic-insert="true|false"

select-before-update="true|false"

polymorphism="implicit|explicit"

where="arbitrary sql where condition"

persister="PersisterClass"

batch-size="N"

optimistic-lock="none|version|dirty|all"

lazy="true|false"

entity-name="EntityName"

check="arbitrary sql check condition"

rowid="rowid"

subselect="SQL expression"

abstract="true|false"

node="element-name"

/>

Hibernate 第一个体验程序的更多相关文章

  1. TODO:即将开发的第一个小程序

    TODO:即将开发的第一个小程序 微信小程序是一种全新的连接用户与服务的方式,它可以在微信内被便捷地获取和传播,同时具有出色的使用体验.个人理解小程序是寄宿在微信平台上的一个前端框架,具有跨平台功能, ...

  2. ASP.NET MVC 5 03 - 安装MVC5并创建第一个应用程序

    不知不觉 又逢年底, 穷的钞票 所剩无几. 朋友圈里 各种装逼, 抹抹眼泪 MVC 继续走起.. 本系列纯属学习笔记,如果哪里有错误或遗漏的地方,希望大家高调指出,当然,我肯定不会低调改正的.(开个小 ...

  3. Unity Shaders 第一个默认程序分析

    Unity Shaders 第一个默认程序 Shader "Custom/Shader" { Properties { _MainTex ("Base (RGB)&quo ...

  4. Maven的第一个小程序

    这里是介绍关于maven的第一个小程序 关于maven的安装 : Install Maven in your computer 先看看目录结构: 这是本来的项目目录结构,由于maven有自己的目录结构 ...

  5. Xamarin iOS编写第一个应用程序创建工程

    Xamarin iOS编写第一个应用程序创建工程 在Xcode以及Xamarin安装好后,就可以在Xamarin Studio中编写程序了.本节将主要讲解在Xamarin Studio中如何进行工程的 ...

  6. 创建ArcGIS API for JavaScript的第一个示例程序

    原文:创建ArcGIS API for JavaScript的第一个示例程序 在上一篇博客中已经介绍了如何搭建ArcGIS API for JavaScript开发环境,如果您还没有搭建好开发环境的话 ...

  7. Linux学习笔记20——第一个多线程程序

    一 什么是线程 线程:是一个进程内部的一个控制序列. 二 使用POSIX的注意点 1 为了使用线程函数库,必须定义宏_REENTRANT,通过定义_REENTRANT来告诉编译器我们需要可重入功能,可 ...

  8. python爬虫__第一个爬虫程序

    前言 机缘巧合,最近在学习机器学习实战, 本来要用python来做实验和开发环境 得到一个需求,要爬取大众点评中的一些商户信息, 于是开启了我的第一个爬虫的编写,里面有好多心酸,主要是第一次. 我的文 ...

  9. 跟Google学习Android开发-起始篇-构建你的第一个应用程序(4)

    说明:此系列教程翻译自Google Android开发者官网的Training教程,利用Chome浏览器的自动翻译功能作初译,然后在一些语句不顺或容易造成误解的地方作局部修正.方便英文不好的开发者查看 ...

随机推荐

  1. 苹果Itools

    韩梦飞沙  韩亚飞  313134555@qq.com  yue31313  han_meng_fei_sha

  2. 【DFS】【图论】NOIP2014寻找道路

    [NOIP2014]寻找道路 题目描述 Description 在有向图G中,每条边的长度均为1,现给定起点和终点,请你在图中找一条从起点到终点的路径,该路径满足以下条件: 1.路径上的所有点的出边所 ...

  3. HDU 6041 I Curse Myself(二分+搜索)

    [题目链接] http://acm.hdu.edu.cn/showproblem.php?pid=6041 [题目大意] 给出一个仙人掌图,求第k小生成树 [题解] 首先找到仙人掌图上的环,现在的问题 ...

  4. 【(博弈)dfs序+树状数组】BZOJ2819-Nim

    [题目大意] 普通的Nim游戏为:两个人进行游戏,N堆石子,每回合可以取其中某一堆的任意多个,可以取完,但不可以不取.谁不能取谁输.这个游戏是有必胜策略的.现在对每一堆编号1,2,3,4,...n,在 ...

  5. [转]Spring MVC 事务配置

    Spring MVC事务配置 要了解事务配置的所有方法,请看一下<Spring事务配置的5种方法> 本文介绍两种配置方法:  <tx:advice/>就是告诉事务管理器:怎么做 ...

  6. 大于非负整数N的第一个回文数 Symmetric Number

    1.题目 如标题,求大于整数N(N>=0)的第一个回文数的字符串表示形式. 2.样例 1  --> 2 9  -->11 12345 -->12421 123456 --> ...

  7. 错误:Caused by:org.apache.spark.SparkException: Kryo serialization failed: Buffer overflow.Available: 0, required: 21. To avoid this,

    这个是写入Redis时用的序列化器,然后错误提示是超过了大小限制,把配置调大即可. .set("spark.kryoserializer.buffer.max","128 ...

  8. POJ 2019 Cornfields (二维RMQ)

    Cornfields Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 4911   Accepted: 2392 Descri ...

  9. Fork & vfork & clone (转载)

    转自:http://blog.csdn.net/zqy2000zqy/archive/2006/09/04/1176924.aspx 进程是一个指令执行流及其执行环境,其执行环境是一个系统资源的集合, ...

  10. 如何在sublime3项目设置中设置python模块的搜索路径?ImportError: No module named *的解决办法

    问题:之前使用pycharm,用的挺溜,但是电脑配置实在不争气,pycharm启动久了,耗去大量内存,导致运行起来越来越慢,于是转向使用sublime text. 把项目从pycharm切换到subl ...