首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >碎片化 | 第四阶段-48-hibernate概述和配置-视频

碎片化 | 第四阶段-48-hibernate概述和配置-视频

作者头像
码神联盟
发布2018-04-02 16:40:52
7800
发布2018-04-02 16:40:52
举报
文章被收录于专栏:码神联盟码神联盟
本套视频从Java基础到架构模式以及AI算法,整体视频以“碎片化”学习的模式,提供给大家 ,并配备实际项目为案例,让大家在坐车、吃饭、午休、蹲坑的时候,都可以学习到N个知识点,目前所有知识点将是免费观看,如果你从中有所收获,烦请关注并转发分享,将是对康哥最大的支持。
视频内容

如清晰度低,可转PC网页观看高清版本:

http://v.qq.com/x/page/h0567lzrhs1.html



版权声明:本视频、课件属本公众号作者所有,如有侵权,将追究法律责任。

视频课件:


Hibernate

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主键管理

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()设置主键值
本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2017-11-02,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 码神联盟 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Hibernate
    • 数据库工具类
      • 增删改查操作
        • Hibernate主键管理
        相关产品与服务
        云数据库 MySQL
        腾讯云数据库 MySQL(TencentDB for MySQL)为用户提供安全可靠,性能卓越、易于维护的企业级云数据库服务。其具备6大企业级特性,包括企业级定制内核、企业级高可用、企业级高可靠、企业级安全、企业级扩展以及企业级智能运维。通过使用腾讯云数据库 MySQL,可实现分钟级别的数据库部署、弹性扩展以及全自动化的运维管理,不仅经济实惠,而且稳定可靠,易于运维。
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档