标签:知识库 打印 截图 content strong r文件 author config users
百度百科上是这样写道的:Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,它将POJO与数据库表建立映射关系,是一个全自动的orm框架,hibernate可以自动生成SQL语句,自动执行,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库。 Hibernate可以应用在任何使用JDBC的场合,既可以在Java的客户端程序使用,也可以在Servlet/JSP的Web应用中使用,最具革命意义的是,Hibernate可以在应用EJB的J2EE架构中取代CMP,完成数据持久化的重任。
Hibernate,翻译过来是冬眠的意思,正好现在已经进入秋季,世间万物开始准备冬眠了。其实对于对象来说就是持久化。
持久化(Persistence),即把数据(如内存中的对象)保存到可永久保存的存储设备中(如磁盘)。持久化的主要应用是将内存中的对象存储在关系型的数据库中,当然也可以存储在磁盘文件中、XML数据文件中等等。
持久化是将程序数据在持久状态和瞬时状态间转换的机制。
JDBC就是一种持久化机制。文件IO也是一种持久化机制。
日常持久化的方法:
1、将鲜肉冷藏,吃的时候再解冻的方法也是。
2、将水果做成罐头的方法也是。
一、Hibernate是对JDBC进一步封装
原来没有使用Hiberante做持久层开发时,存在很多冗余,如:各种JDBC语句,connection的管理,所以出现了Hibernate把JDBC封装了一下,我们不用操作数据,直接操作它就行了。
二、我们再从分层的角度来看
我们知道非常典型的三层架构:表示层,业务层,还有持久层。Hiberante也是持久层的框架,而且持久层的框架还有很多,比如:IBatis,Nhibernate,JDO,OJB,EJB等等。
三、Hibernate是开源的一个ORM(对象关系映射)框架。
ORM,即Object-Relational Mapping,它的作用就是在关系型数据库和对象之间做了一个映射。从对象(Object)映射到关系(Relation),再从关系映射到对象。这样,我们在操作数据库的时候,不需要再去和复杂SQL打交道,只要像操作对象一样操作它就可以了(把关系数据库的字段在内存中映射成对象的属性)
O, Object 对象 ——R, Realtion 关系 (关系型数据库: MySQL, SQLServer…)——M,Mapping 映射( Hibernate是ORM的实现!)
ORM, 解决什么问题?
存储: 能否把对象的数据直接保存到数据库?
获取: 能否直接从数据库拿到一个对象?
ORM保存了对象和关系型数据库的映射信息,映射信息保存在xml的配置文件中

Hibernate六大核心接口,两个主要配置文件,以及他们直接的关系。Hibernate的所有内容都在这了。那我们从上到下简单的认识一下,每个接口进行一句话总结。
1、Configuration接口:负责配置并启动Hibernate
2、SessionFactory接口:负责初始化Hibernate
3、Session接口:负责持久化对象的CRUD操作
4、Transaction接口:负责事务
5、Query接口和Criteria接口:负责执行各种数据库查询
注意:Configuration实例是一个启动期间的对象,一旦SessionFactory创建完成它就被丢弃了。
搭建hibernate环境的步骤
1、下载源码:
如:版本:hibernate-distribution-3.6.0.Final
2、引入jart文件(案例的jar文件)
Hibernate3.jar核心+required必须引入的留个jar文件 + Jpa + 数据库驱动包,如下截图

3、写入对象以及对象的映射(映射文件)
(1)、User.java
package com.gqx.demo1;
/**
* 对象
* @author 郭庆兴
*
*/
public class User {
private int id;
private String name;
private String password;
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 getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
}
(2)。User.hbm.xml
<?xml version="1.0"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd"> <hibernate-mapping package="com.gqx.demo1"> <class name="User" table="users"> <!-- 主键字段 --> <id name="id" column="uid"> <generator class="native"/> </id> <!-- 非主键 --> <property name="name" column="name"></property> <property name="password" column="password"></property> </class> </hibernate-mapping>
4、 src/hibernate.cfg.xml 主配置文件
——>数据库连接配置
——> 加载所用的映射(*.hbm.xml)
hibernate.cfg.xml文件如下
<!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN" "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd"> <hibernate-configuration> <session-factory> <!-- 数据库连接配置 --> <property name="hibernate.connection.driver_class">com.microsoft.sqlserver.jdbc.SQLServerDriver</property> <property name="hibernate.connection.url">jdbc:sqlserver://localhost:1433;DataBaseName=Test</property> <property name="hibernate.connection.username">sa</property> <property name="hibernate.connection.password">123456</property> <!-- 生成指定的sql语言 --> <property name="hibernate.dialect">org.hibernate.dialect.SQLServerDialect</property> <!-- 为了更好的展示效果,在控制台打印sql语句 --> <property name="hibernate.show_sql">true</property> <!-- 加载所有映射 --> <mapping resource="com/gqx/demo1/User.hbm.xml"/> </session-factory> </hibernate-configuration>
5. App.java 测试
package com.gqx.demo1;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
import org.hibernate.classic.Session;
import org.junit.Test;
public class App {
@Test
public void test() {
//对象
User user=new User();
user.setName("Hibernate");
user.setPassword("111");
//获取加载配置文件的管理类型對对象
Configuration config=new Configuration();
config.configure(); //默认加载src/hibernate.cfg.xml文件
//创建session的工厂对象
SessionFactory sf=config.buildSessionFactory();
//创建session(session代表一个会话,与数据库连接的会话)
Session session=sf.openSession();
//开启事物
Transaction tx=session.beginTransaction();
//对象保存到数据库
session.save(user);
//提交事务
tx.commit();
//关闭
session.close();
sf.close();
}
}
运行结果控制台如图:

这个时候会发现数据库表users的信息会多了一条。
js小练习——移动的小方块,效果如图:

代码如下:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>走口字练习</title>
<style type="text/css" media="screen">
* {
margin: 0;
padding: 0;
}
#div1 {
width: 500px;
height: 500px;
border: 10px #000 solid;
margin: 20px auto;
position: relative;
}
#div2 {
width: 100px;
height: 100px;
background: red;
position: absolute;
left: 0;
top: 0;
}
</style>
</head>
<script type="text/javascript">
window.onload = function() {
var oDiv1 = document.getElementById(‘div1‘);
var oDiv2 = document.getElementById(‘div2‘);
var arr1 = [‘left‘, ‘top‘, ‘left‘, ‘top‘]; //控制方向
var arr2 = [10, 10, -10, -10]; //控制每个方向对应的速度大小
var arr3 = [400, 400, 0, 0];
var arr4 = [0, 400, 400, 0];
setInterval(function() {
if (parseInt(getStyle(oDiv2, ‘left‘)) == arr3[iNow] && parseInt(getStyle(oDiv2, ‘top‘)) == arr4[iNow]) {
if (iNow == 3) {
iNow = 0;
} else {
iNow++;
}
}
oDiv2.style[arr1[iNow]] = parseInt(getStyle(oDiv2, arr1[iNow])) + arr2[iNow] + ‘px‘;
}, 50);
//可以通过这种方式去设置属性
oDiv2.style[‘background‘]=‘green‘;
var iNow = 0; //表示方向
//根据兼容性的不同获取属性
function getStyle(obj, attr) {
if (obj.currentStyle) {
return obj.currentStyle[attr];
} else {
return getComputedStyle(obj, false)[attr];
}
}
}
</script>
<body>
<div id="div1">
<div id="div2"></div>
</div>
</body>
</html>
标签:知识库 打印 截图 content strong r文件 author config users
原文地址:http://www.cnblogs.com/helloworldcode/p/6266492.html