Hibernate操作步骤

1.新建项目

2.加jar包

3.写XML配置文件hibernate.cfg.xml

4.写log4j.properties日志文件

5.在MySql数据库中建student表

6.建Student实体类(先建表后建类)

7.写XML映射文件Student.hbm.xml,或者Annotation映射语句

8.在hibernate.cfg.xml中添加相应mapping

9.写测试类main,或者Junit测试类(项目右键-->“New”-->“Junit Test Case”)

HelloWorld小程序----XML映射文件

1.新建项目

2.加jar包。此处列出的jar包是Hibernate所需的全部jar包,在此项目中并不是全部需要

将如下jar包封装进一个User Library,名为hibernate

antlr-2.7.6.jar
c3p0-0.9.1.jar
commons-collections-3.1.jar
dom4j-1.6.1.jar
hibernate3.jar
hibernate-annotations.jar
hibernate-commons-annotations.jar
hibernate-jpa-2.0-api-1.0.0.Final.jar
javassist-3.12.0.GA.jar
jta-1.1.jar
junit-4.10.jar
log4j-1.2.14.jar
mysql-connector-java-5.1.7-bin.jar
slf4j-api-1.6.1.jar
slf4j-log4j12-1.6.1.jar

3.hibernate.cfg.xml配置文件。其中<mapping/>在步骤8中设置

<?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/test</property>
<property name="connection.username">root</property>
<property name="connection.password">root</property> <!-- JDBC connection pool 连接池 -->
<!-- <property name="connection.pool_size">1</property> --> <!-- SQL dialect 方言-->
<property name="dialect">org.hibernate.dialect.MySQLDialect</property> <!-- 当前session上下文 . thread:当前线程;jta:(java transaction api) -->
<property name="current_session_context_class">thread</property> <!-- Disable the second-level cache 去掉二级缓存 -->
<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 常用选项:create和update -->
<property name="hbm2ddl.auto">update</property> <mapping resource="com/hibernate/model/Student.hbm.xml"/>
<!-- <mapping class="com.hibernate.model.Student"/> --> </session-factory>
</hibernate-configuration>

4.log4j.properties日志文件

### direct log messages to stdout ###
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target=System.out
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L - %m%n ### direct messages to file hibernate.log ###
#log4j.appender.file=org.apache.log4j.FileAppender
#log4j.appender.file.File=hibernate.log
#log4j.appender.file.layout=org.apache.log4j.PatternLayout
#log4j.appender.file.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L - %m%n ### set log levels - for more verbose logging change 'info' to 'debug' ### log4j.rootLogger=warn, stdout #log4j.logger.org.hibernate=info
#log4j.logger.org.hibernate=debug ### log HQL query parser activity
#log4j.logger.org.hibernate.hql.ast.AST=debug ### log just the SQL
#log4j.logger.org.hibernate.SQL=debug ### log JDBC bind parameters ###
#log4j.logger.org.hibernate.type=info
#log4j.logger.org.hibernate.type=debug ### log schema export/update ###
#log4j.logger.org.hibernate.tool.hbm2ddl=debug ### log HQL parse trees
#log4j.logger.org.hibernate.hql=debug ### log cache activity ###
#log4j.logger.org.hibernate.cache=debug ### log transaction activity
#log4j.logger.org.hibernate.transaction=debug ### log JDBC resource acquisition
#log4j.logger.org.hibernate.jdbc=debug ### enable the following line if you want to track down connection ###
### leakages when using DriverManagerConnectionProvider ###
#log4j.logger.org.hibernate.connection.DriverManagerConnectionProvider=trace

5.在数据库中建表

建表可以在数据库中手动建,也可以通过运行程序自动建立。

此处自动建表

6.建Student实体类

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;
}
}

7.Student.hbm.xml映射文件

<?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>
<class name="com.hibernate.model.Student" dynamic-update="true">
<id name="id">
<generator class="native"></generator> <!-- generator设置其id自增 -->
</id> <!-- id指的是相应表的主键 -->
<property name="name"></property>
<property name="age"></property>
</class> </hibernate-mapping>

8.在hibernate.cfg.xml中添加相应mapping

9.写测试类main

public class StudentTest {
public static void main(String[] args) {
Student s = new Student();
s.setName("s3");
s.setAge(10); SessionFactory sf = new Configuration().configure().buildSessionFactory(); Session session = sf.getCurrentSession();
session.beginTransaction();
session.save(s);
session.getTransaction().commit(); sf.close();
} }

程序到此结束,运行后,会自动在数据库创建student表,并将对象s存入student表中。

HelloWorld小程序----Annotation映射语句

步骤1-5同上

6,7.建实体类,添加Annotation注解

@Entity   //表示这是一个实体类,和数据库中的某个表是对应的
public class Teacher {
private int id;
private String name;
private int age; @Id //主键
@GeneratedValue //ID生成策略,默认为AUTO
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;
}
}

8.在hibernate.cfg.xml中添加相应mapping,如下

<mapping class="com.hibernate.model.Student"/>

9.写测试类

测试类有很多种方式

a)见上文测试类main

b)创建一个HibernateUtil辅助类 ,然后再建测试类main

public class HibernateUtil {
private static SessionFactory sf = buildSessionFactory(); private static SessionFactory buildSessionFactory() {
return new Configuration().configure().buildSessionFactory();
}
public static SessionFactory getSessionFactory() {
return sf;
}
}

 

public class StudentTest {
public static void main(String[] args) {
Student s = new Student();
s.setName("lisi");
s.setAge(18); SessionFactory sf = HibernateUtil.getSessionFactory(); Session session = sf.getCurrentSession();
session.beginTransaction();
session.save(s);
session.getTransaction().commit(); sf.close();
}
}

c)建Junit测试类

项目右键-->“New”-->“Junit Test Case”,输入类名,然后完善test方法

public class StudentTest_Junit {
private static SessionFactory sf = null; @BeforeClass
public static void beforeClass(){
sf = new Configuration().configure().buildSessionFactory();
} @AfterClass
public static void afterClass(){
sf.close();
} @Test
public void test() {
Student s = new Student();
s.setName("wangwu");
s.setAge(23); Session session = sf.getCurrentSession();
session.beginTransaction();
session.save(s);
session.getTransaction().commit();
}
}

程序到此结束,运行后,会自动在数据库创建student表,并将对象s存入student表中。

Hibernate_HelloWord的更多相关文章

随机推荐

  1. 个人博客开发之 全局配置文件settings设置

    项目源码下载:http://download.vhosts.cn # -*- coding: utf-8 -*- """ Django settings for cpyb ...

  2. 离散数学及其应用(Discrete Mathematica With Application 7th)学习笔记 第一章

    目前本人只进行到了第五章的章末补充练习,应该是从4月6号开始学习的,又是英文版,而且基本就下班回家抽2个小时左右去学,所以进度较慢. 由于本质是数学,除了一些程序处理和大计算量的问题,基本上一本草稿本 ...

  3. 关闭数据库时SHUTDOWN: waiting for active calls to complete.处理

    有时候在关闭数据库时,发出shutdown immediate;命令后一直未关闭.查看ALERT日志.在等待一段时间后日志中有提示: SHUTDOWN: waiting for active call ...

  4. 将Mac上的***代理共享给其他设备

    Windows版***带有Share over LAN功能,可以让一些不方便安装***客户端的设备一同“鸡犬升天”,如未越狱的iOS设备.但是 OS X 就没有这么幸运了,这时候你需要Privoxy助 ...

  5. js与jquery实时监听输入框值的oninput与onpropertychange方法

    文实例讲述了js与jquery实时监听输入框值的oninput与onpropertychange方法.分享给大家供大家参考.具体如下: 最近做过一个项目,需求是下拉框里自动匹配关键字,具体细节是实时监 ...

  6. poj 1548(最小路径覆盖)

    题目链接:http://poj.org/problem?id=1548 思路:最小路径覆盖是很容易想到的(本题就是求最小的路径条数覆盖所有的点),关键是如何建图,其实也不难想到,对于当前点,如果后面的 ...

  7. 小知识,大智慧(restframework 拾忆)

    一.直接对query_set序列化,在页面展示的效果是Unicode 编码格式 ,可在json 序列化时候加入一个参数 course_query = DegreeCourse.objects.all( ...

  8. linux中使用vi 打开文件时,能显示行号

    方法一: 1.显示当前行行号,在VI的命令模式下输入 :nu 2.显示所有行号,在VI的命令模式下输入     :set nu方法二: 使用vi编辑~/.vimrc文件,在该文件中加入一行" ...

  9. Python 内置函数、作用域、闭包、递归

    一.内置函数如何使用 help()一下: 如想看min()咋用?在shell中:help(min) 二.部分内置函数 (一).排序:sorted() li = [(1, 2, 3, 4), (7, 8 ...

  10. 【转】再谈CLR查找和加载程序集的方式

    这是一个老问题,以前也有朋友写过一些文章介绍,但可能还不是很全面.我也多次被人问到,这里结合案例再次谈谈,希望对大家有所帮助. 本文范例代码可以通过这里下载 http://files.cnblogs. ...