答:
1)Hibernate是一个操作数据库的框架,实现了对JDBC的封装;
2)Hibernate是一个ORM(对象关系映射)框架,我们在写程序时 ,用的时面向对象的方法,但是在关系型数据库里,存的是一条条的数据,为了用纯面向对象的思想解决问题,所有需要将程序中的对象和数据库的记录建立起映射关系,ORM就是这样的技术,而Hibernate就是这样一个框架,以操作对象的方式操作数据库。
3)Hibernate简化了代码的编写,原生态的JDBC需要很对代码来实现操作数据库,在这里用Hibernate只需要很少的代码就可以实现。
4)使用Hibernate的基本流程是:配置实现类与数据库表的映射关系,产生sessionFactory,打开session通道拿到session对象,开启事务,完成操作,关闭session。
5)Hibernate屏蔽了数据库的差异,增强了对数据库的可移植性。
6)使用Hibernate时,先要配置hibernate.cfg.xml文件,其中配置数据库连接信息和方言等,还要为每个实体配置相应的hbm.xml文件(Hibernate的映射文件),当然,也可以采用注解编程实现映射关系,hibernate.cfg.xml文件中需要登记每个hbm.xml文件
1)读取并解析配置文件
2)读取并解析映射信息,创建SessionFactory
3)打开Sesssion
4)创建事务Transation
5)持久化操作
6)提交事务
7)关闭Session
8)关闭SesstionFactory
为什么要用:
1)对JDBC访问数据库的代码做了封装,大大简化了数据访问层繁琐的重复性代码。
2)Hibernate是一个基于JDBC的主流持久化框架,是一个优秀的ORM实现。他很大程度的简化DAO层的编码工作
3)hibernate使用Java反射机制,而不是字节码增强程序来实现透明性。
4)hibernate的性能非常好,因为它是个轻量级框架。映射的灵活性很出色。它支持各种关系数据库,从一对一到多对多的各种复杂关系。
答: Sql、Criteria,objectcomposition
Hql:
1)属性查询
2)参数查询、命名参数查询
3)关联查询
4)分页查询
5)统计函数
答:
1)使用双向一对多关联,不使用单向一对多
2)灵活使用单向一对多关联
3)不用一对一,用多对一取代
4)配置对象缓存,不使用集合缓存
5)一对多集合使用Bag,多对多集合使用Set
6)继承类使用显式多态
7)表字段要少,表关联不要怕多,有二级缓存撑腰
答:
1)建索引
2)减少表之间的关联
3)优化sql,尽量让sql很快定位数据,不要让sql做全表查询,应该走索引,把数据量大的表排在前面
4)简化查询字段,没用的字段不要,已经对返回结果的控制,尽量返回少量数据
注:另有需要JAVA、Android、IOS、Python、C++、HTML5全套视频教程的朋友,请搜索关注“误入编程界的程序猿”,私信我哦~~~