maven hbm2java_hibernate4-hbm.xml基本使用-Maven Demo

目录结构如图,

80082ead8660e4ace1e64e2b5d3dbacc.png

1.用MyEclipse建立一个Maven-Java项目,然后给出pom配置,

xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">

4.0.0

com.xuebaosoft.hibernate4

hibernate4-maven-conf

0.0.1-SNAPSHOT

jar

hibernate4-maven-conf

http://maven.apache.org

UTF-8

junit

junit

3.8.1

test

org.hibernate

hibernate-core

4.2.8.Final

org.slf4j

slf4j-simple

1.6.1

mysql

mysql-connector-java

5.1.6

2.环境准备好以后写一个pojo-UserModel.java,

package modelTest;

public class UserModel {

private String uuid;

private int userId;

private String name;

private int age;

public String getUuid() {

return uuid;

}

public void setUuid(String uuid) {

this.uuid = uuid;

}

public int getUserId() {

return userId;

}

public void setUserId(int userId) {

this.userId = userId;

}

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;

}

}

3.配置hibernate数据源环境xml--hibernate.cfg.xml,

hibernate-configuration PUBLIC

"-//Hibernate/Hibernate Configuration DTD 3.0//EN"

"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">

com.mysql.jdbc.Driver

jdbc:mysql://192.168.191.1:3306/mysql

root

root

org.hibernate.dialect.MySQLDialect

true

create

解释下:

show_sql为true表示在执行数据库操作的时候sql语句会以log的形式打印在console;

hbm2ddl.auto为create表示先删除指定的实体-关系表(不管存在不存在都先执行删除操作),然后再进行操作,这个也算是hibernate的主要实用优势之一,不用你写sql建表了。

mapping这里对应了实体-关系表的配置文件

4.实体-关系表的配置--UserModel.hbm.xml

hibernate-mapping PUBLIC

'-//Hibernate/Hibernate Mapping DTD 3.0//EN'

'http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd'>

解释下,

name为modelTest.UserModel对应的是那个POJO,table为tbl_user表示对应数据库的那个表

id标识userId字段为主键,其余的都不是主键,generator为native或者是increment表示自增,这里有篇帖子希望了解区别的可以参考下:**(帖子我忘了,找个机会补),总之native是本地化的方案,可能会使用increment进行代替,可以理解为native是一个抽象父类,increment是一个实现它的具体类,但具体类不止increment一个,这里自增主键用native和increment都是可以的(官方demo用的就是increment)

这样配置好以后就可以进行测试了。

5.使用JUnit进行测试,

package foo;

import junit.framework.Test;

import junit.framework.TestCase;

import junit.framework.TestSuite;

import modelTest.UserModel;

import org.hibernate.Session;

import org.hibernate.SessionFactory;

import org.hibernate.Transaction;

import org.hibernate.cfg.Configuration;

public class AppTest extends TestCase {

private SessionFactory sessionFactory;

public AppTest(String testName) {

super(testName);

}

protected void setUp() throws Exception {

sessionFactory = new Configuration().configure().buildSessionFactory();

}

protected void tearDown() throws Exception {

if (sessionFactory != null) {

sessionFactory.close();

}

}

public static Test suite() {

return new TestSuite(AppTest.class);

}

public void testApp() {

UserModel um = new UserModel();

um.setUuid("1");

um.setName("name1");

um.setAge(1);

Session s = sessionFactory.openSession();

Transaction t = s.beginTransaction();

s.save(um);

t.commit();

}

}

6.分析一下,

首先数据库mysql会删除tbl_user这张表,然后重建,之后就是插入一条记录

f49aa83b263ffd254a897d566c4a3a86.png

关键代码也就是

sessionFactory = new Configuration().configure().buildSessionFactory();

然后用这个sessionFactory去open一个session,

Session s = sessionFactory.openSession();

再之后就用这个session利用hibernate操作数据库,就是这么一个过程,

Transaction t = s.beginTransaction();

s.save(um);

t.commit();

其中这个POJO就是让这个session的save使用的,这样就会在ORM的框架下插入一条记录。

文章的意义也就是记录下Hibernate4用的哪些Jar包,还有基本的配置过程。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值