day_02使用注解的方式进行操作hibernate定义实体

星期二, 十二月 29, 2015 21:20:00

 

 

使用注解的方式进行操作hibernate定义实体

 

步骤:

1.引入hibernate-annotations.jar

   "hibernate-commons-annotations.jar"

   "ejb3-persistence.jar" 

2.建一个Teacher类

3.在数据库中建teacher表

   create table teacher(id int primary key,name varchar(20),title varchar(20));

4.在Teacher加入注解:@Entity   //主键@Id

 

/*1.实体类(使用annotation进行实现,告诉hibernate是实体类,

 * 不需要再建立Teacher.hbm.xml文件进行映射)

 * 2.hibernate.cfg.xml进行配置即可

 * 3.建立一个TeacherTest

*/

 

5.在hibernate.cfg.xml进行配置

 

 <mapping class="com.zhuhw.hibernate.Teacher"/>

 

6.建立TeacherTest类

 

//因为使用的annotation,所以Configuration要使用AnnotationConfiguration

Configuration cf = new AnnotationConfiguration();

 

运行即可

 

 

代码案例:

package com.zhuhw.hibernate;

import javax.persistence.Entity;
import javax.persistence.Id;

/*1.实体类(使用annotation进行实现,告诉hibernate是实体类,
 * 不需要再建立Teacher.hbm.xml文件进行映射)
 * 2.hibernate.cfg.xml进行配置即可
 * 3.建立一个TeacherTest
*/
@Entity
public class Teacher {
		private int id;
		private String name;
		private String title;
		//主键
		@Id
		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 String getTitle() {
			return title;
		}
		public void setTitle(String title) {
			this.title = title;
		}
	
		
}

 

 

 

<?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) -->
       <!--  <property name="connection.pool_size">1</property> -->

        <!-- SQL dialect -->
        <property name="dialect">org.hibernate.dialect.MySQLDialect</property>

        <!-- Enable Hibernate's automatic session context management -->
        <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 -->
        <property name="show_sql">true</property>

        <!-- Drop and re-create the database schema on startup -->
       <!--   <property name="hbm2ddl.auto">update</property>-->
		<!-- hibernate去哪里找这个配置文件 -->
        <mapping resource="com/zhuhw/hibernate/Student.hbm.xml"/>
        
        <mapping class="com.zhuhw.hibernate.Teacher"/>

    </session-factory>

</hibernate-configuration>

 

 

 

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

import com.zhuhw.hibernate.Student;
import com.zhuhw.hibernate.Teacher;


public class TeacherTest {
	public static void main(String[] args){
		Teacher t = new Teacher();
		t.setId(2);
		t.setName("yuzhou");
		t.setTitle("aaaa");
		
		//因为使用的annotation,所以Configuration要使用AnnotationConfiguration
		
		Configuration cf = new AnnotationConfiguration();
		SessionFactory sf = cf.configure().buildSessionFactory();
		Session session = sf.openSession();
		//在hibernate中执行操作要在一个事务里面
		session.beginTransaction();
		session.save(t);
		session.getTransaction().commit();
		session.close();
		sf.close();
		
	}
}

 

运行结果:

Hibernate: insert into Teacher (name, title, id) values (?, ?, ?)

 

 

总结:

1.请务必建立自己动手查一手文档的能力

2.重要的是

     1.要建立了自己动手查一手文档的信心

     2.还有建立自己动手查一手文档的习惯

     3.主动学习,放弃被动接受灌输的习惯

 

 

星期二, 十二月 29, 2015   22:10:48

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值