Hibernate
Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,它将POJO与数据库表建立映射关系,是一个全自动的orm框架,hibernate可以自动生成SQL语句,自动执行,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库。 Hibernate可以应用在任何使用JDBC的场合,既可以在Java的客户端程序使用,也可以在Servlet/JSP的Web应用中使用,最具革命意义的是,Hibernate可以在应用EJB的J2EE架构中取代CMP,完成数据持久化的重任。
Hibernate核心API
Session
SessionFactory
Transaction
Query
Criteria
Configuration
ORM(Object Relational Mapping)
对象关系映射,是一种程序技术,用于实现面向对象编程语言里不同类型系统的数据之间的转换。从效果上说,它其实是创建了一个可在编程语言里使用的--“虚拟对象数据库”。
Hibernate配置文件
<?xml version="1.0" encoding="UTF-8"?> <!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> <!-- 配置方言 告诉hibernate 是使用哪种类型的数据库 --> <property name="dialect">org.hibernate.dialect.MySQLDialect</property> <!-- 配置mysql的驱动 --> <property name="connection.driver_class">com.mysql.jdbc.Driver</property> <!-- 配置mysql的url 注意不要空格 --> <property name="connection.url">jdbc:mysql://127.0.0.1:3306/jg33</property> <!-- 配置用户名 --> <property name="connection.username">root</property> <!-- 配置数据库密码 --> <property name="connection.password">root</property> <!-- 配置显示sql语句 --> <property name="show_sql">true</property> <!-- 格式化sql语句 --> <property name="format_sql">true</property> <!-- 配置自动创建表 -->
<!-- 内涵4个参数
create:创建,但是如果有表则会删除表,表示无论以前是否有表都会删除以前的表,每次运行都是如此;
delete:删除表;
create-drop:加载hibernate时创建,退出是删除表结构;
update:有表则不管,执行操作,没有则创建表 --> <property name="hbm2ddl.auto">create</property> <!-- 映射orm的xml student.hbm.xml --> <!-- <mapping resource="com/my/cfg/student.hbm.xml"/> --> <mapping class="com.my.bean.User"/> </session-factory> </hibernate-configuration>
创建关系映射文件
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd"> <!--package 对包文件进行映射 --> <hibernate-mapping package="com.my.bean"> <!--对哪个实体bean进行映射 name必须对应的类的名字 table对应你要映射的表名 --> <!-- table和 column 可以省略,默认:表对应类名, 列名:对应对象属性--> <class name="Student" table="t_student"> <!--对应的标识符, id对应属性的id(标识符) type 可选择项--> <id name="id" column="sid" type="java.lang.Integer"> <!--配置主键的生成策略 hibernate自动增长id --> <generator class="increment"></generator> </id> <property name="name" column="name" type="java.lang.String" ></property> <property name="birthday" column="birthday"></property> </class> </hibernate-mapping>
事务处理
事务是一组组合成逻辑工作单元的数据库操作,在系统执行过程中可能会出错,但事务将控制和维护每个数据库的一致性和完整性。事务处理的主要特征是,任务要么全部 完成,要么都不完成。在写入一些记录时,要么写入所有记录,要么什么都不写入。如果在写入一个记录时出现了一个失败,那么在事务处理中已写入的其他数据就 会回滚。
1)数据库上锁:LOCK TABLES tablename WRITE;(多个用户同时操作同一个数据库同一表格,可能造成数据不同步,显示无效数据。那么给表格上锁,可以使数据有效性。比如A给表格上锁,操作时,B查看不到数据库,需要等待A解锁数据库)
2)数据库解锁:UNLOCK TABLES tablename;(解锁表格)
3)数据库回滚:ROLLBACK;
4)数据关闭/开启自动提交功能:SET AUTOCOMMIT=0/1;
5)数据库提交:COMMIT;(提交后不能事物回滚)
6)设置保存点:SAVEPOINT name;(设置保存点为name,回滚跳转保存点为:ROLLBACK TO name)
7)删除保存点:RELEASE SAVEPOINT;