第一个hibernate程序HelloWorldHibernate
HelloWorldHibernate步骤:
HelloWorld
1,新建java项目hibernate_0100_HelloWorld
2,学习User-library-hibernate,并加入相应的jar包
a)项目右键-build path-configure build path-add library
b)选择User-library,在其中新建library,命名hibernate
c)在该library中加入hibernate所需的包
- /required必须的包
- Sl4j jar日志包
- bytecode生成二进制字节码需要的
3,引入mysql的JDBC驱动包
4,在mysql中建立对应的数据库及表
a)create database hibernate;
b)use hibernate
c)create table student (id int primary key,name varchar(20),age int );
5,建立hibernate配置文件hibernate.cfg.xnl
a),从参考文档中copy
b),修改对应的数据库连接
c),注释掉暂时用不上的内容
6,建立Student类
7,建立Student映射文件Student.hbm.xml
映射关系:
哪个类-----------------------哪个表
类属性----------------------表字段
a)参考文档
8,将映射文件加入到hibernate.cfg.xml
<mapping resource="com/oracle/hibernate/model/Student.hbm.xml"/>
a)参考文档
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
项目架构:

package com.oracle.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;
}
}
Hibernate.cfg.xml配置文件:
<?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> <!-- Database connection settings -->
<property name="connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="connection.url">jdbc:mysql://localhost/hibernate</property>
<property name="connection.username">root</property>
<property name="connection.password">root</property> <!-- JDBC connection pool (use the built-in) -->
<!-- hibernate自带的连接池,实际开发一般用applicationserver本身用jndi注册在里面的连接池 -->
<!-- <property name="connection.pool_size">1</property> --> <!-- SQL dialect -->
<!-- 方言,hibernate已经统一了数据库的访问,他的HQL语句就是官方语言,但不过最终还是翻译成具体不同数据库的sql语句,(搜文档mysql)-->
<property name="dialect">org.hibernate.dialect.MySQLDialect</property> <!-- Enable Hibernate's automatic session context management -->
<!-- 3.2以后新加的内容,涉及到session。。。 -->
<!-- <property name="current_session_context_class">thread</property> --> <!-- Disable the second-level cache -->
<!-- 把二级缓存disable掉,优化hibernate -->
<property name="cache.provider_class">org.hibernate.cache.NoCacheProvider</property> <!-- Echo all executed SQL to stdout -->
<!-- 要不要打印生成的sql语句 -->
<property name="show_sql">true</property> <!-- Drop and re-create the database schema on startup -->
<!-- hbm(hibernatemapping) ,ddl(建表语句。是否自动生成建表语句)-->
<!-- <property name="hbm2ddl.auto">update</property> --> <mapping resource="com/oracle/hibernate/model/Student.hbm.xml"/> </session-factory> </hibernate-configuration>
Student.hbm.xml配置文件:
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> <!-- 映射的是哪个package里的类 -->
<hibernate-mapping package="com.oracle.hibernate.model">
<!-- 类到表的映射 类名若和表名一致,table可以省略--> <class name="Student">
<id name="id"></id>
<property name="name"></property>
<property name="age"></property>
</class> </hibernate-mapping>
Test类:
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration; import com.oracle.hibernate.model.Student; public class StudentTest { /**
* @param args
*/
public static void main(String[] args) {
Student s = new Student(); s.setId(3);
s.setName("student3");
s.setAge(3); /**
* Configuration.configure()读配置文件的。
*Document,File,Sting ,Url四种重载方法,默认是读取src下的hibernate.cfg.xml
*/
Configuration cfg = new Configuration(); /**
* cfg.configure()已经把hibernate.cfg.xml解析了,返回值还是Configuration,
* 是已经有了配置选项的Configuration对象。
* buildSessionFactory()暂时理解为产生Connection的一个工厂
*/
SessionFactory sf = cfg.configure().buildSessionFactory();
Session session = sf.openSession();//打开新的Session /**
* 在hibernate里边的操作都应放在一个事务里
* session.beginTransaction()返回值Transaction,可以把他存在来。随便
*/
session.beginTransaction();
/**
* save时,先看s是Student类,然后去hibernate.cfg.xml配置文件找
* <mapping resource="XXX.hbm.xml"/>
* 看是否有这个配置文件,找到后,看他的映射关系,类和数据库表的映射关系,然后拼成sql语句
* 自动连数据库,自动生成preparedStatement,自动执行executeUpdate
*/
session.save(s); /**
* 拿到当前事务,提交
*/
session.getTransaction().commit(); session.close(); //关闭session
sf.close(); //关闭工厂
} }
注意:hibernate.cfg.xml名字不能改,约定俗成。Student.hbm.xml放在我们的Model类的包里。
session.save(s);方法执行图示:

save时,先看s是Student类,然后去hibernate.cfg.xml配置文件找 <mapping resource="com/oracle/hibernate/model/Student.hbm.xml"/>, 看是否有这个Student的类配置文件,找到后,看他的映射关系,类和数据库表的映射关系,类的属性和表字段的映射关系。然后拼成sql语句,自动连数据库,自动生成preparedStatement,自动执行executeUpdate,数据就保存到了数据库。
查找出单个对象,修改,删除代码如下:
//查询出id=1的Student
Student s = (Student)session.get(Student.class,1); System.out.println(s);
//修改信息
s.setAge(20);
session.update(s);
//删除一个对象
//session.delete(s); ts.commit(); if(session != null){
if(session.isOpen())
session.close();
}
sf.close();
第一个hibernate程序HelloWorldHibernate的更多相关文章
- 攻城狮在路上(壹) Hibernate(二)--- 第一个hibernate程序
1.直接通过JDBC API持久化实体域对象: A.java.sql常用接口和类: DriverManager:驱动程序管理器,负责创建数据库连接. Connection:代表数据库连接. State ...
- Hibernate入门(1)-第一个Hibernate程序
Hibernate入门(1)-第一个Hibernate程序 Hibernate是最著名的ORM工具之一,本系列文章主要学习Hibernate的用法,不涉及Hibernate的原理.本文介绍第一个Hib ...
- 第一个Hibernate程序
一 新建一个Java工程(Hibernate) 在src目录下创建一个名为"hibernate.cfg.xml"的文件并配置好各个属性,如下: <?xml version=& ...
- hibernate入门配置及第一个hibernate程序
学习了hibernate后就想先给大家分享一下它的配置方法: jar包导入 一.数据库表的创建 二.开启hibernate配置 编译器:eclipse 数据库:mysql 1.创建第一个xml文件 ...
- 我的第一个Hibernate程序
1.建表建序列(所用数据库为Oracle,数据库名为XE,创建用户hibernate,密码为123456) conn system/manager; ; grant connect to hibern ...
- 【SSH三大框架】Hibernate基础第一篇:编写第一个Hibernate程序
接下来这几章节学习的是Hibernate,Hibernate的主要作用就是用来和数据库进行连接,简化了JDBC的操作. 首先,我们创建项目,然后把Hibernate的jar包和sqlserver的驱动 ...
- 第一个Hibernate 程序
使用MyEclipse建立Hibernate工程 index页面的Jsp源文件 <%@ page language="java" import="java.util ...
- Java程序员从笨鸟到菜鸟之(五十一)细谈Hibernate(二)开发第一个hibernate基本详解
在上篇博客中,我们介绍了<hibernate基本概念和体系结构>,也对hibernate框架有了一个初步的了解,本文我将向大家简单介绍Hibernate的核心API调用库,并讲解一下它的基 ...
- 一个Hibernate小程序
基本步骤 在前一篇博文Hibernate环境搭建中为大家详细的介绍如何搭建一个学习新类库的学习环境.今天,为大家带来一个Hibernate小例子,让大家能够快速上手. 步骤如下: 1.配置hibern ...
随机推荐
- SpringBoot整合mybatis、shiro、redis实现基于数据库的细粒度动态权限管理系统实例
1.前言 本文主要介绍使用SpringBoot与shiro实现基于数据库的细粒度动态权限管理系统实例. 使用技术:SpringBoot.mybatis.shiro.thymeleaf.pagehelp ...
- OpenSSL命令---crl2pkcs7
用途: 本命令根据CRL或证书来生成pkcs#7消息. 用法: openssl crl2pkcs7 [-inform PEM|DER ] [-outform PEM|DER ] [-in filena ...
- Java下的框架编程(反射,泛型,元数据,CGLib,代码动态生成,AOP,动态语言嵌入)
Java 虽然没有动态语言般暴起,但仍然天连天,水接水的生出好多框架技术---反射(reflection),泛型(generics),元数据(annotation),proxies(proxy/cgl ...
- [label][paypal] Paypal 支付页面的语言显示问题
答复 Frank 通过 Email2014-11-12 02:01 上午 您好 感谢您联系PayPal商家技术支持中心. PayPal登陆页面的语言是PayPal服务器根据以下各种因素来自动判断的:1 ...
- Android-进程理解/进程的优先级别
进程理解 Android系统最小的控制单元是:进程 process 应用/CPU最小的控制单元是:线程 thread 一个应用一个 process 进程 一个应用一个 package(包是唯一的) 一 ...
- nancy中的身份验证
在nancy中,身份验证分为basic ,form ,token,stateless几种,basic和form这里不说了,其中如果是使用cookie来保存身份的, 需要注意的是:cookie有大小的限 ...
- TFS 2015新功能之一,当前迭代查询标记
TFS 2015发布在即,有幸作为MVP提前获得了TFS的RTM版本,下面就TFS 2015的新功能做一些介绍: TFS 2015新功能之一,当前迭代查询标记 在TFS的查询中,可以将" ...
- 存储系统的基本数据结构之一: 跳表 (SkipList)
在接下来的系列文章中,我们将介绍一系列应用于存储以及IO子系统的数据结构.这些数据结构相互关联又有着巨大的区别,希望我们能够不辱使命的将他们分门别类的介绍清楚.本文为第一节,介绍一个简单而又有用的数据 ...
- PostgreSQL查询数据(基本查询)
原料:数据表 create table "SysUser"( "UserId" serial, --用户Id,自增 "UserName" ) ...
- Android 异步网络图片加载
ListView异步加载图片 http://www.eoeandroid.com/forum.php?mod=viewthread&tid=161586 [Android分享] ListVie ...
