hibernate是一个采用ORM(Object/Relation Mapping对象关系映射)机制持久层的开源框架
其主要核心思想是面向对象,而非面向过程,而这个面向对象则主要通过ORM实现。
ORM是将表与表之间的操作,映射成对象和对象之间的操作,就是通过操作实体类来达到操作表的目的。从数据库提取的数据会自动按你设置的映射要求封装成特定的对象。之后你就可以通过对对象进行操作来修改数据库中的数据。这时候你面对的不是信息的碎片,而是一个形象鲜明的对象。
最简单的情况下,hibernate把数据表的数据段映射到类的属性上,那么这个数据表的定义本身就对应于一个类的定义,而每一个数据行将映射成该类的一个对象。
所以hibernate就是通过将数据表和实体类之间的映射,使得对对象的修改对应数据行的修改,不用考虑关系型的数据库表,使得程序思考角度完全对象化,更符合面向对象思维,同时也简化了持久层的代码,使逻辑结构更清晰。
下面是一个简单的入门例子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="dialect">
org.hibernate.dialect.SQLServerDialect
</property>
<property name="connection.url">
jdbc:microsoft:sqlserver://localhost:1433
</property>
<property name="connection.username">sa</property>
<property name="connection.password">zzq</property>
<property name="connection.driver_class">
com.microsoft.jdbc.sqlserver.SQLServerDriver
</property>
<property name="myeclipse.connection.profile">
SQLServer
</property>
<!--实体类映射文件位置 hbm.xml文件 -->
<mapping resource="hibernate/Student.hbm.xml" />
</session-factory>
</hibernate-configuration>
实体类
public class Student implements java.io.Serializable {
private Integer id;
private String name;
private Integer age;
public Integer getId() {
return this.id;
}
public void setId(Integer id) {
this.id = id;
}
public String getName() {
return this.name;
}
public void setName(String name) {
this.name = name;
}
public Integer getAge() {
return this.age;
}
public void setAge(Integer age) {
this.age = age;
}
}
实体类的映射文件 *.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">
<!--
Mapping file autogenerated by MyEclipse Persistence Tools
-->
<hibernate-mapping>
<pre name="code" class="html"> <!-- 对应的实体类 表 数据库 -->
<class name="hibernate.Student" table="student" schema="dbo" catalog="Student"> <id name="id" type="java.lang.Integer">
<column name="id" />
<pre name="code" class="html"> <!--主键策略生成器 -->
<generator class="assigned" /> </id> <property name="name" type="java.lang.String"> <column name="name"/> </property> <property name="age" type="java.lang.Integer"> <column name="age" /> </property> </class></hibernate-mapping>
获取session操作数据库
public class HibernateSessionFactory{
public static void main(String[] args) {
//读取hibernate.cfg.xml文件
Configuration cfg = new Configuration().configure();
//建立SessionFactory
SessionFactory sf=cfg.buildSessionFactory();
//打开session
Session s=sf.openSession();
Student u = new Student();
u.setName("zzq");
u.setAge(18);
u.setName("zzqzzq");
u.setAge(18);
Transaction t=s.beginTransaction();//提取事务
s.save(u);//录入数据
//s.update(u,5);//更行主键为5的数据
/
//删除主键为5的数据
// u.setId(5);
// s.delete(u);
/*
* 查询 ,只能根据主键查询
* Student ss=(Student) s.get(Student.class,6);
* System.out.println(ss);
*/
/
/*
* 查询数据库全部内容
*
Query q = s.createQuery("FROM Student");
System.out.println(q.list());
*/
//运行HQL语言 进行表操作
Query q = s.createQuery("SELECT s FROM Student s WHERE s.name = ? OR s.age = ?");
q.setString(0, "zzq");
q.setString(1, "18");
List<Student> l=q.list();
for(int i=0;i<l.size();i++){
Student st =l.get(i);
System.out.println(st.getId() +" "+st.getName()+" "+st.getAge() );
}
t.commit();//保存事务
s.close();//关闭session
System.out.println("结束");
}
}