01基本内容

1 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>
		<!-- 数据库连接信息 -->
		<property name="connection.url">jdbc:oracle:thin:@localhost:1521:orcl</property>
		<property name="connection.username">scott</property>
		<property name="connection.password">tiger</property>
		<property name="connection.driver_class">oracle.jdbc.OracleDriver</property>
		
		<property name="dialect">org.hibernate.dialect.OracleDialect</property>
		<property name="show_sql">true</property>
		<property name="format_sql">true</property>
		
		<mapping resource="model/Emp.hbm.xml"/>
		
	</session-factory>
</hibernate-configuration>

2 Emp.hbm.xml

<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC
	"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
	"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
	
<hibernate-mapping>
	<class name="model.Emp" table="testempbydf">
		<id name="id" type="java.lang.Integer" column="id">
			<generator class="sequence">
				<param name="sequence">emp_seq</param>
			</generator>
		</id>
		
		<property name="name" type="java.lang.String" column="name"></property>
		<property name="age" type="java.lang.Integer" column="age"></property>
		<property name="salary" type="java.lang.Double" column="salary"></property>
	</class>
</hibernate-mapping>

3 数据库,这里用的oracle

CREATE TABLE testempbydf (
  ID        NUMBER(4) CONSTRAINT EMP_ID_PK PRIMARY KEY,
  NAME      VARCHAR(50) NOT NULL,
  AGE       NUMBER(11),
  SALARY    NUMBER(7,2)
);

CREATE SEQUENCE emp_seq
INCREMENT BY 1 -- 每次加1
START WITH 100 -- 100开始
NOMAXvalue     -- 无最大值
NOCYCLE        -- 不循环
CACHE 10;      -- 设置缓存cache

4 导包,hibernate相关的,JDBC相关的

5 HibernateUtil.java

package util;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;

public class HibernateUtil {
	private static SessionFactory sf;
	
	static {
		Configuration conf = new Configuration();
		conf.configure("/hibernate.cfg.xml");
		sf = conf.buildSessionFactory();
	}
	
	public static Session getSession() {
		return sf.openSession();
	}
}

6 测试

package test;

import java.util.List;

import model.Emp;

import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.Transaction;

import util.HibernateUtil;

public class Test {
	@org.junit.Test
	public void testAdd() {
		Emp e = new Emp();
		e.setName("zhangfei");
		e.setAge(27);
		e.setSalary(2000.0);
		
		Session session = HibernateUtil.getSession();
		Transaction ts = session.beginTransaction();
		try {
			session.save(e);
			ts.commit();
		} catch (Exception e2) {
			e2.printStackTrace();
			ts.rollback();
		} finally {
			session.close();
		}
	}
	
	@org.junit.Test
	public void findById() {
		Emp emp = new Emp();
		Session session = HibernateUtil.getSession();
		emp = (Emp) session.get(Emp.class, 1);
		System.out.println(emp.getId() + " " + emp.getName() + " " + emp.getAge() + " " + emp.getSalary());
		session.close();
	}
	
	@org.junit.Test
	public void update() {
		// 模拟数据
		Emp emp = new Emp();
		emp.setId(3);
		emp.setName("zhaoyun");
		emp.setAge(22);
		emp.setSalary(1800.0);
		
		Session session = HibernateUtil.getSession();
		Transaction ts = session.beginTransaction();
		try {
			session.update(emp);
			ts.commit();
		} catch (Exception e) {
			e.printStackTrace();
			ts.rollback();
		} finally {
			session.close();
		}
	}
	@org.junit.Test
	public void delete() {
		// 模拟数据
		Emp emp = new Emp();
		emp.setId(3);
		
		Session session = HibernateUtil.getSession();
		Transaction ts = session.beginTransaction();
		try {
			session.delete(emp);
			ts.commit();
		} catch (Exception e) {
			e.printStackTrace();
			ts.rollback();
		} finally {
			session.close();
		}
	}
	
	@org.junit.Test
	public void findAll() {
		String hql = "from Emp";
		Session session = HibernateUtil.getSession();
		Query query = session.createQuery(hql);
		@SuppressWarnings("unchecked")
		List<Emp> emps = query.list();
		for (Emp emp : emps) {
			System.out.println(emp.getId() + " " + emp.getName() + " " + emp.getAge() + " " + emp.getSalary());
		}
	}
}


你可能感兴趣的:(01基本内容)