发表于: 2017-12-30 21:54:15

1 392


今天完成的事:

       看了看Hibernate

明天计划的事:

        随便看看

问题:

收获:

Hibernate是一个数据持久化层的ORM框架.

Object:对象,java对象,此处特指JavaBean

Relational:关系,二维表,数据库中的表。

映射|映射元数据:对象中属性,与表的字段,存在对应关系。


Hibernate对JDBC访问数据库的代码做了封装,大大简化了数据访问层繁琐的重复性代码

Hibernate是一个基于jdbc的主流持久化框架,是一个优秀的orm实现,它很大程度的简化了dao层编码工作  session.save(User);

Hibernate使用java的反射机制

Hibernate的性能非常好,因为它是一个轻量级框架。映射的灵活性很出色。它支持很多关系型数据库,从一对一到多对多的各种复杂关系


!-- SessionFactory,相当于之前学习连接池配置 -->

<session-factory>

<!-- 1 基本4-->

<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>

<property name="hibernate.connection.url">jdbc:mysql:///h_day01_db</property>

<property name="hibernate.connection.username">root</property>

<property name="hibernate.connection.password">1234</property>

<!-- 2 与本地线程绑定 -->

<property name="hibernate.current_session_context_class">thread</property>

 

   <!-- 3 方言:为不同的数据库,不同的版本,生成sql语句(DQL查询语句)提供依据

    * mysql 字符串 varchar

    * orcale 字符串 varchar2

   -->

   <property name="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</property>

<!-- 4 sql语句 -->

<!-- 显示sql语句 -->

<property name="hibernate.show_sql">true</property>

<property name="hibernate.format_sql">true</property>

<!-- 5 自动创建表(了解) ,学习中使用,开发不使用的。

* 开发中DBA 先创建表,之后根据表生产 PO

* 取值:

update:【】

如果表不存在,将创建表。

如果表已经存在,通过hbm映射文件更新表(添加)。(映射文件必须是数据库对应)

表中的列可以多,不负责删除。

create :如果表存在,先删除,再创建。程序结束时,之前创建的表不删除。【】

create-drop:与create几乎一样。如果factory.close()执行,将在JVM关闭同时,将创建的表删除了。(测试)

validate:校验 hbm映射文件 表的列是否对应,如果对应正常执行,如果不对应抛出异常。(测试)

-->

<property name="hibernate.hbm2ddl.auto">create</property>

<!-- 6 java web 6.0 存放一个问题

* BeanFactory 空指针异常

异常提示:org.hibernate.HibernateException: Unable to get the default Bean Validation factory

* 解决方案:取消bean校验

-->

<property name="javax.persistence.validation.mode">none</property>

<!-- 添加映射文件

<mapping >添加映射文件

resource 设置 xml配置文件 addResource(xml)

class 配置类 (addClass(User.class)) 配置的是全限定类名

-->

<mapping  resource="com/itheima/a_hello/User.hbm.xml"/>

</session-factory>




hibernate执行hql语句

hql语句:hibernate提供面向对象查询语句,使用对象(类)和属性进行查询。区分大小写。

获得 session.createQuery("hql")

方法:

list()  查询所有

uniqueResult() 获得一个结果。如果没有查询到返回null,如果查询多条抛异常。

setFirstResult(int) 分页,开始索引数startIndex

setMaxResults(int) 分页,每页显示个数 pageSize



返回列表 返回列表
评论

    分享到