首页 > Web开发 > 详细

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

时间:2015-12-30 02:03:55      阅读:260      评论:0      收藏:0      [点我收藏+]

星期二, 十二月 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

?

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

原文:http://yuzhouxiner.iteye.com/blog/2267528

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!