Hibernate 第一个体验程序
首先要导入包,将下载的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 第一个体验程序的更多相关文章
- TODO:即将开发的第一个小程序
TODO:即将开发的第一个小程序 微信小程序是一种全新的连接用户与服务的方式,它可以在微信内被便捷地获取和传播,同时具有出色的使用体验.个人理解小程序是寄宿在微信平台上的一个前端框架,具有跨平台功能, ...
- ASP.NET MVC 5 03 - 安装MVC5并创建第一个应用程序
不知不觉 又逢年底, 穷的钞票 所剩无几. 朋友圈里 各种装逼, 抹抹眼泪 MVC 继续走起.. 本系列纯属学习笔记,如果哪里有错误或遗漏的地方,希望大家高调指出,当然,我肯定不会低调改正的.(开个小 ...
- Unity Shaders 第一个默认程序分析
Unity Shaders 第一个默认程序 Shader "Custom/Shader" { Properties { _MainTex ("Base (RGB)&quo ...
- Maven的第一个小程序
这里是介绍关于maven的第一个小程序 关于maven的安装 : Install Maven in your computer 先看看目录结构: 这是本来的项目目录结构,由于maven有自己的目录结构 ...
- Xamarin iOS编写第一个应用程序创建工程
Xamarin iOS编写第一个应用程序创建工程 在Xcode以及Xamarin安装好后,就可以在Xamarin Studio中编写程序了.本节将主要讲解在Xamarin Studio中如何进行工程的 ...
- 创建ArcGIS API for JavaScript的第一个示例程序
原文:创建ArcGIS API for JavaScript的第一个示例程序 在上一篇博客中已经介绍了如何搭建ArcGIS API for JavaScript开发环境,如果您还没有搭建好开发环境的话 ...
- Linux学习笔记20——第一个多线程程序
一 什么是线程 线程:是一个进程内部的一个控制序列. 二 使用POSIX的注意点 1 为了使用线程函数库,必须定义宏_REENTRANT,通过定义_REENTRANT来告诉编译器我们需要可重入功能,可 ...
- python爬虫__第一个爬虫程序
前言 机缘巧合,最近在学习机器学习实战, 本来要用python来做实验和开发环境 得到一个需求,要爬取大众点评中的一些商户信息, 于是开启了我的第一个爬虫的编写,里面有好多心酸,主要是第一次. 我的文 ...
- 跟Google学习Android开发-起始篇-构建你的第一个应用程序(4)
说明:此系列教程翻译自Google Android开发者官网的Training教程,利用Chome浏览器的自动翻译功能作初译,然后在一些语句不顺或容易造成误解的地方作局部修正.方便英文不好的开发者查看 ...
随机推荐
- 安卓 内存泄漏 MemoryAnalyzer
韩梦飞沙 yue31313 韩亚飞 han_meng_fei_sha 313134555@qq.com 需要 获取 root 权限 步骤: 1,使用eclipse 自带的 DDMS 工具分析各线程的内 ...
- [BZOJ1494]生成树计数
[BZOJ1494] [NOI2007]生成树计数 Description 最近,小栋在无向连通图的生成树个数计算方面有了惊人的进展,他发现:·n个结点的环的生成树个数为n.·n个结点的完全图的生成树 ...
- 【树形dp】Treasure Hunt I
[ZOJ3626]Treasure Hunt I Time Limit: 2 Seconds Memory Limit: 65536 KB Akiba is a dangerous coun ...
- django查询
阅读目录 大于.大于等于 小于.小于等于 在...范围内 模糊查询 是否为空 不等于/不包含于 大于.大于等于 1 2 3 4 5 __gt 大于 __gte 大于等于 User.objects. ...
- static_cast, dynamic_cast, reinterpret_cast, const_cast的区别
static_cast最像C风格的强制转换,很多时候都需要程序员自身去判断转换是否安全.但是相对C风格的强制转换,在无关类的类指针之间转换上,有安全性的提升. dynamic_cast是运行时的转换吧 ...
- KNN算法实现手写数字
from numpy import * import operator from os import listdir def classify0(inX, dataSet, labels, k): d ...
- 模仿.Net ThreadPool的线程池控件
http://www.2ccc.com/btdown.asp?articleid=5953 ftp://download:S3cirpYW3DoR@www.2ccc.com/vcl/system/20 ...
- PatchGuard Disabled V3
https://twitter.com/Fyyre http://www.m5home.com/bbs/thread-5893-1-1.html http://pan.baidu.com/share/ ...
- 如何使用 DBCC MEMORYSTATUS 命令来监视 SQL Server 2005 中的内存使用情况
https://technet.microsoft.com/en-us/solutionaccelerators/dd537566.aspx 注意:这篇文章是由无人工介入的微软自动的机器翻译软件翻译完 ...
- 普通项目转换成maven项目
参看文档:http://czj4451.iteye.com/blog/1983889 maven仓库:http://mvnrepository.com/ 基本步骤如下: Configue--& ...