如清晰度低,可转PC网页观看高清版本:
http://v.qq.com/x/page/h0567lzrhs1.html
版权声明:本视频、课件属本公众号作者所有,如有侵权,将追究法律责任。
视频课件:
jdbc->jdbcTemplate -> mybatis ->Hibernate
用于操作数据库中的数据,ORM工具,类似于我们的mybatis,是为我们操作持久层提供的开源框架
hibernate和mybatis的对比:
1:hibernate学习难度大于mybatis
2:hibernate扩展功能强于mybatis
3:hibernate提供自带的事物、缓存、二级缓存等
4:hibernate支持自带分页功能,mybatis使用插件进行分页
5:hibernate目前行情很少使用了,多数用于大型传统公司老项目
6:mybatis应用与大型的互联网项目。eg:网站、中间件、CRM\SCRM、ERP、APP等等
7:hibernate整合ssh,复杂度大于mybatis
8:hierbnate自己生成sql语句,mybatis需要手工编写sql语句
结构:
1:导包
2:增加配置文件
3:加载一些配置数据库信息
结构图:
要获取Session---org.hibernate
/**
* 获取数据库连接session
* @return
*/
public static Session getSession(){
Configuration conf = new Configuration();
conf.configure("hibernate.cfg.xml");//读取hibernate配置文件
SessionFactory sessionFactory = conf.buildSessionFactory();//创建session工厂
Session session = sessionFactory.openSession();//建立session连接工厂
return session;
}
1:查询
session.get(Entity.class, id);
2:增加
session.save(Entity);
3:删除
session.delete(Entity);
4:修改
注意:首先查询要修改的实体对象,然后修改
session.update(Entity);
事物使用:
Transaction ts = session.beginTransaction();//开启事物连接
//TODO 增删改操作代码
ts.commit();//提交事物
session.close();//关闭session
Hibernate提供了很多内置的主键生成器,可以在添加时自动生成主键值。
1.sequence 序列
适用于Oracle数据库
2.identity 主键自动生成
适用于MySQL、SQLServer数据库
3.native
代表hibernate会自动识别当前连接数据库类型,eg:mysql、oracle
如果是mysql数据库,那么此时的主键生成策略则为identity
如果是oracle数据库,那么此时的主键生成策略为:sequence
4.increment
可以不给主键ID进行set值,默认是使用数据表的主键ID最大值+1作为ID值
5.uuid/hilo
采用uuid或hilo算法生成一个主键值。uuid生成一个字符串值
6.assigned
默认值。在进行添加操作时,程序员需要在代码中使用setXxx()设置主键值