1、事务
Hibernate的任何对数据有改动的操作,都应该被放在事务里面.
在事务中的多个操作行为,要么都成功,要么都失败
2、效果
在同一个事务中做了两件事情
- 删除id=1的产品
- 修改id=2的产品,使得其产品名称超过了数据库中设置的长度30.
提交事务。
第二个任务失败了,但是因为在同一个事务中,所以第一个任务也没有生效。因此id=1的产品,依然保留下来了。
3、TestHibernate 事务
hibernate中的事务由s.beginTransaction();开始
由s.getTransaction().commit();结束
本例子,执行了两个操作
第一个,删除id=1的产品,这个是会成功的
第二个,修改id=2的产品,使得其产品名称超过了数据库中设置的长度30,这个是会失败的。
因为这两个操作都是在一个事务中,而且第二个操作失败了,所以最后的结果是两个操作都没有生效
package com.how2java.test;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;
import com.how2java.pojo.Product;
public class TestHibernate {
public static void main(String[] args) {
SessionFactory sf = new Configuration().configure().buildSessionFactory();
Session s = sf.openSession();
s.beginTransaction();
Product p = (Product) s.get(Product.class, 1);
s.delete(p);
Product p2 = (Product) s.get(Product.class, 2);
p2.setName("长度超过30的字符串作为产品名称长度超过30的字符串作为产品名称长度超过30的字符串作为产品名称长度超过30的字符串作为产品名称");
s.update(p2);
s.getTransaction().commit();
s.close();
sf.close();
}
}
4、MYSQL 表的类型必须是INNODB才支持事务
在Mysql中,只有当表的类型是INNODB的时候,才支持事务,所以需要把表的类型设置为INNODB,否则无法观察到事务.
修改表的类型为INNODB的SQL:
alter table product_ ENGINE = innodb;
查看表的类型的SQL
show table status from test;
不过有个前提,就是当前的MYSQL服务器本身要支持INNODB,如果不支持,请看 开启MYSQL INNODB的办法
5、属性的延迟加载
hibernate中的延迟加载(lazyload)分属性的延迟加载和关系的延迟加载
属性的延迟加载:
当使用load的方式来获取对象的时候,只有访问了这个对象的属性,hibernate才会到数据库中进行查询。否则不会访问数据库
6、演示属性的延迟加载
在打印log1之前,是不会打印出sql语句的,只有在访问属性“getName()"的时候,才会访问数据库
package com.how2java.test;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;
import com.how2java.pojo.Product;
public class TestHibernate {
public static void main(String[] args) {
SessionFactory sf = new Configuration().configure().buildSessionFactory();
Session s = sf.openSession();
s.beginTransaction();
Product p = (Product)s.load(Product.class, 1);
System.out.println("log1");
System.out.println(p.getName());
System.out.println("log2");
s.getTransaction().commit();
s.close();
sf.close();
}
}
7、参考链接
[01] How2j - Hibernate - 事务
[02] How2j - Hibernate - 属性的延迟加载