上一篇讲的是hibernate的环境搭建,因为现在大部分公司在使用Annotation来操作实体类进而进行表的建立,免去了写Xxx.hbm.xml表映射文件的烦恼,所以我再写一个用Annotation来操作实体类的例子:
导包什么的我就不说了,详情看上一篇吧,直接切入主题:
1.首先说说什么是注解(Annotation),这个学过Java基础的人应该不陌生,这里只说一下在hibernate框架里如何使用。
@符号后面加一个名字就是Annotation
使用注解Annotation时用的jar包。 包括:
hibernate-commons-annotations-3.3.0.ga.jar //进行反射时需要的包
hibernate-entitymanager.jar
ejb3-persistence.jar //符合jpa标准的annotation的实现
hibernate-annotations.jar
jpa是一个标准,hibernate是一个实现
JDBC是一个标准,各个数据库的驱动是实现
注意,3.5以后的hibernate已经包含了Annotation时用的jar包,所以上面的包都不需要再次添加!!
2.工程部分源码的分享:
数据库中创建teacher表
建立Teacher实体类(不用添加Annotation的jar包,因为hb3.5以后的都加过了):
package cn.edu.hpu.model;
import javax.persistence.Entity;
import javax.persistence.Id;
//‘@+语句’就叫做注解
//@Entity表示这家伙是个实体类(一个表中的对象)
@Entity
public class Teacher {
private String name;
private int id;
private String title;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
//@Id告诉hibernate这个是主键
@Id
public int getId() {
return id;
}
//不加默认就是@Basic
public void setId(int id) {
this.id = id;
}
public String getTitle() {
return title;
}
public void setTitle(String title) {
this.title = title;
}
}
在hibernate.cfg.xml中配置:
<mapping class="cn.edu.hpu.model.Teacher"/>
测试类
TeacherTest.java:
package cn.edu.hpu.test;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.AnnotationConfiguration;
import org.hibernate.cfg.Configuration;
import cn.edu.hpu.model.Teacher;
public class TeacherTest {
public static void main(String[] args) {
Teacher t=new Teacher();
t.setId(2);
t.setName("t2");
t.setTitle("中级");
//AnnotationConfiguration是用来专门读Annotation配置的
Configuration cfg=new AnnotationConfiguration();
//文件下的 <mapping resource=.....
SessionFactory sf=cfg.configure().buildSessionFactory();
//buildSessionFactory()可以理解为能得到conn的类
//暂时把Session理解成数据库的Connection
Session session=sf.openSession();//得到session
session.beginTransaction();
session.save(t);
session.getTransaction().commit();
session.close();
sf.close();
}
}
运行TeacherTest.java后控制台输出:
Hibernate: insert into Teacher (name, title, id) values (?, ?, ?)
数据成功添加到数据库中
转载请注明出处!程序猿之洞:http://blog.csdn.net/acmman/