Hibernate中可以通过.hbm.xml配置来完成表的创建,啰嗦麻烦。但是之后出现JPA注解。使用JPA注解,开发人员可以不用编写.hbm.xml文件,只需在持久化类中加JPA注解。相关的JPA注解如下:
1、@Entity //标识这个pojo是一个jpa实体
2、@Table(name = "users") //设置表名,指定表名为users
3、@Id //设置主键
4、@Column //设置字段,与表中字段duiying
.unique:是否唯一 || .nullable:是否可以为空 || .inserttable:是否可以插入 || .updateable:是否可以更新 || .columnDefinition: 定义建表时创建此列的DDL
例:@Column(name = "user_code", nullable = false, length=32)//设置属性userCode对应的字段为user_code,长度为32,非空
5、@GeneratedValue(strategy=GenerationType.IDENTITY) //主键自增
6、@OrderBy //字段排序
以上就是常见的JPA注解,下面使用一个基本的程序来实际介绍一下JPA注解
第一步、建立一个Java项目,名为Hibernate_one
第二步、导入jar包,加载jar包,在src下创建了lib文件夹,用来存放jar包(jar包必须一个都不能少)。如图
我连接的数据库是Oracle,所以得加载Oracle的驱动包ojdbc6,如果用mysql数据库,可从网上下载mysql的驱动包。并将包buildpath
第三步、配置hibernate(作用是连接数据库,必不可少!!!)
在src目录下建立xml文件,命名为:hibernate.cfg.xml
配置内容如下:
oracle.jdbc.driver.OracleDriver
scottscottorg.hibernate.dialect.Oracle9Dialect
[html] view plain copy
truetrue
update
以上就是Hibernate配置的详细,不同数据库配置语句不同,自己搜索即可
第四步、创建持久化类,并实现set/get方法及toString。使用JPA注解,则在持久类中编写
创建一个包,名为com.aisino.hibernate.JPA,下面创建持久化类Class_01
package com.aisino.hibernate.JPA;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Table;
//持久化类
//映射实体类
@Entity(name="Class0924")
@Table
public class Class_01 {
//注意查看JPA注解
//主键
@Id
@GeneratedValue(strategy=GenerationType.AUTO)//表示主键自增
private int classId;
@Column(name="className")
private String className;
@Column(name="classCount")
private String classCount;
//构造方法
public Class_01(){
}
public int getClassId() {
return classId;
}
public void setClassId(int classId) {
this.classId = classId;
}
public String getClassName() {
return className;
}
public void setClassName(String className) {
this.className = className;
}
public String getClassCount() {
return classCount;
}
public void setClassCount(String classCount) {
this.classCount = classCount;
}
@Override
public String toString() {
return "Class [classCount=" + classCount + ", classId=" + classId
+ ", className=" + className + "]";
}
}
第五步、编写Hibernate的工具类,如下代码
package com.aisino.hibernate.source;
import org.hibernate.HibernateException;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;
public class HibernateUtil {
public static final SessionFactory sessionFactory;
public static final ThreadLocal session = new ThreadLocal();
static{
try{
Configuration configuration=new Configuration().configure();
sessionFactory = configuration.buildSessionFactory();
}catch (Throwable ex){
System.err.println("Initial SessionFactory creation failed." + ex);
throw new ExceptionInInitializerError(ex);
}
}
public static Session currentSession() throws HibernateException{
Session s = (Session) session.get();
if (s == null)
{
s = sessionFactory.openSession();
session.set(s);
}
return s;
}
public static void closeSession() throws HibernateException {
Session s = (Session) session.get();
if (s != null)
s.close();
session.set(null);
}
}
第七步、写一个类ClassTest,进行单元测试,创建表以及实现增删改查
package com.aisino.hibernate.JPA;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
import org.junit.Test;
//测试类
public class TestClass {
//建表
@Test
public void CreateTable(){
//配置Hibernate
Configuration cfg=new Configuration();
cfg.configure();
cfg.buildSessionFactory();
}
//添加数据
@Test
public void AddUser(){
//配置Hibernate
Configuration cfg=new Configuration();
cfg.configure();
//产生SessionFacorty
SessionFactory sessionFactory=cfg.buildSessionFactory();
//打开Session
Session session=sessionFactory.openSession();
//开启事物
Transaction transaction=session.beginTransaction();
//实例化持久化类
Class_01 cl=new Class_01();
//添加数据
cl.setClassId(3);
cl.setClassName("土木工程");
cl.setClassCount("5个班");
//执行添加操作
session.save(cl);
//事物提交
transaction.commit();
//关闭session
session.close();
}
//修改
@Test
public void Update(){
//Hibernate配置
Configuration cfg=new Configuration();
cfg.configure();
//产生SessionFactory
SessionFactory sessionFactory=cfg.buildSessionFactory();
//开启Session
Session session=sessionFactory.openSession();
//开启事物
Transaction transaction = session.beginTransaction();
//获取对象
Class_01 cl=(Class_01) session.get(Class_01.class, 21);
//修改数据
cl.setClassName("文学新闻传播");
cl.setClassCount("2个班");
//保存数据
session.save(cl);
//提交事物
transaction.commit();
//关闭事物
session.close();
}
//删除
@Test
public void Delete(){
//Hibernate配置
Configuration cfg=new Configuration();
cfg.configure();
//产生SessionFactory
SessionFactory sessionFactory=cfg.buildSessionFactory();
//开启session
Session session=sessionFactory.openSession();
//开启事物
Transaction transaction =session.beginTransaction();
//获取要删除的对象
Class_01 cl=(Class_01) session.get(Class_01.class, 22);
//删除
session.delete(cl);
//事物提交
transaction.commit();
//关闭session
session.close();
}
//查询信息(查询不需要开启事物)
@Test
public void Select(){
//配置Hebernate
Configuration cfg=new Configuration();
cfg.configure();
//产生SessionFactory
SessionFactory sessionFactory=cfg.buildSessionFactory();
//打开session
Session session=sessionFactory.openSession();
//获取对象
Class_01 cl=(Class_01) session.get(Class_01.class, 23);
//输出结果
System.out.println(cl.toString());
//关闭session
session.close();
}
}
以上增删改查操作,利用单元测试永兴,并在数据库中查看。
本篇博客介绍的是JPA注解,上一篇博客介绍的是利用.hbm.xml配置文件实习基本的增删改查。初学者可以查看,但建议使用JPA注解