Hibernate开发环境的简单搭建及常见错误(一)下

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
云数据库 RDS PostgreSQL,高可用系列 2核4GB
简介: Hibernate开发环境的简单搭建及常见错误(一)

二.六 创建SessionFactory对象


在service包下,创建一个基本的CreateTest类进行测试。 用Junit4进行测试。


一定要创建到SessionFactory对象。 当出现这个对象时,才会执行自动创建表。


package com.yjl.service;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;
import org.junit.Test;
/**
 @author: 两个蝴蝶飞
 @date: 2018年9月29日 下午8:30:59
 @Description 测试创建User表是否成功
*/
public class CreateTest {
  @Test
  public void createTest(){
    //获取配置
    Configuration config=new Configuration();
    config.configure();
    //创建sessionFactory对象,要到session这一步。
    SessionFactory sessionFactory=config.buildSessionFactory();
                /*上面这是Hibernate 5的写法。 如果用的是Hibernate 4的话,那么是这样,要添加服务登记*/
                /*configuration=new Configuration();
      configuration.configure();
      ServiceRegistry serviceRegistry=new         StandardServiceRegistryBuilder().applySettings(configuration.getProperties()).build(); // 实例化服务登记
      sessionFactory=configuration.buildSessionFactory(serviceRegistry); */
  }
}


二.七 Junit启动createTest方法,进行测试


在进行测试时,出现了两个相当大的问题。


二.七.一 添加Log4j2.xml 日志 文件


报的错误是:


ERROR StatusLogger No log4j2 configuration file found.

Using default configuration: logging only errors to the console.


搜索网上的答案,需要创建一个log4j2.xml文件。 log4j.properties文件不好使。 将log4j.properties文件改成log4j2.properties文件也不好使。只有创建log4j2.xml文件。


在src下,必须是src下创建一个log4j2.xml文件。内容是:


<?xml version="1.0" encoding="UTF-8"?>
<Configuration status="warn">
    <Appenders>
        <Console name="Console" target="SYSTEM_OUT">
            <PatternLayout pattern="%m%n" />
        </Console>
    </Appenders>
    <Loggers>
      <!-- 修改级别为DEBUG -->
        <Root level="DEBUG">
            <AppenderRef ref="Console" />
        </Root>
    </Loggers>
</Configuration>


二.七.二 报创建表时搜索引擎的问题 (楼主MySQL版本为5.5 5.1也会报这个错误。其余版本请忽略)


将log4j2.xml文件添加成功之后,运行时,出现:


20200615094305225.png


Caused by: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException:

You have an error in your SQL syntax;

check the manual that corresponds to your MySQL server

version for the right syntax to use near ‘type=MyISAM’ at line 9


查看了一下MySQL中my.ini中文件的引擎值,为


20200615094316464.png


其实,这是与MySQL无关的。 是Hibernate自己的问题。


在5.5和5.1版本时,MySQL创建的引擎是MyISAM。 其余版本是INNODB。 故其余版本请忽略这个问题。


20200615094328356.png


问题答案出处(感谢!!!): http://jasonhan-sh-hotmail-com.iteye.com/blog/1473955


将hibernate.cfg.xml中的


org.hibernate.dialect.MySQLDialect


改成:


org.hibernate.dialect.MySQL5InnoDBDialect


重新测试: 引擎变成了InnoDB。


20200615094339274.png


表也创建成功了。


三. Hibernate对MySQL方言的支持


对:


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


进行ctrl+鼠标点击,进行查看:


@Deprecated
/*    */ public class MySQL5InnoDBDialect
/*    */   extends MySQL5Dialect
/*    */ {
/*    */   protected MySQLStorageEngine getDefaultMySQLStorageEngine()
/*    */   {
/* 20 */     return InnoDBStorageEngine.INSTANCE;
/*    */   }
        // }


但是这个类MySQL5InnoDBDialect 已经过时了。


它的那个返回值是:


public static final MySQLStorageEngine INSTANCE = new InnoDBStorageEngine();


表示创建的是InnoDB引擎。


它继承了MySQL5Dialect。 查看MySQL5Dialect


public class MySQL5Dialect
 extends MySQLDialect{}


它继承了MySQLDialect 类。这个MySQLDialect表示是关于MySQL的方言。


而MySQLDialect类继承了Dialect类


public class MySQLDialect extends Dialect{}


这个类Dialect自然就是所有数据库类的父类。


ctrl+T, 查看Dialect类的继承结构:


20200615094355743.png


里面有MySQL,有DB2,有Oracle等各个方言。


ctrl+T, 查看MySQL5Dialect


20200615094407861.png


既然MySQL5InnoDBDialect已经过时了,那么Hibernate官方肯定要给一个更好的。此时用MySQL5Dialect试试。


org.hibernate.dialect.MySQL5Dialect


可以运行。 以后都改成MySQL5Dialect了。 刚开始的MySQLDialect太父类了,基本没有什么功能了。


四. 其他常见错误的演示


四.一 没有引入mysql驱动jar包


20200615094418356.png


四.二 User.hibernate.xml中的属性property没有与User类相对应


            <!-- 正确的是:<property name="userName"></property> 
    现在改成写:username-->
    <property name="username"></property> 


20200615094440208.png


四.三 没有引入User.hibernate.xml文件


这个时候,不会报错。 但不会创建user表。 因为hibernate.cfg.xml与User.hibernate.xml没有任何关系。这个问题最难发现,要多注意。


四.四 引入了错误的User.hibernate.xml文件


                <!-- 正确的应该是pojo包下,而不是po包下 -->
    <mapping resource="com/yjl/po/User.hibernate.xml"/>


2020061509445215.png


可以通过ctrl+鼠标进行点击,如何路径正确,会跳转到相应的xml文件。如果不正确,不会进行跳转。


注意此时写的是 ///(斜杠) 文件夹的形式,并不是…(点) 包的形式。(这一点不像MyBatis) 也会报这一个not found的错误。


Hibernate是一个非常牛的框架。建议多学习。


谢谢您的观看,如果喜欢,请关注我,再次感谢 !!!


相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
相关文章
|
XML 存储 缓存
Hibernate开发环境的简单搭建及常见错误(一)上
Hibernate开发环境的简单搭建及常见错误(一)
210 0
Hibernate开发环境的简单搭建及常见错误(一)上
|
SQL 缓存 Java
框架分析(9)-Hibernate
框架分析(9)-Hibernate
|
缓存 Java 数据库连接
Hibernate:Java持久层框架的高效应用
通过上述步骤,可以在Java项目中高效应用Hibernate框架,实现对关系数据库的透明持久化管理。Hibernate提供的强大功能和灵活配置,使得开发者能够专注于业务逻辑的实现,而不必过多关注底层数据库操作。
181 1
|
SQL Java 数据库连接
Hibernate 是一款开源 ORM(对象关系映射)框架,封装了 JDBC,允许以面向对象的方式操作数据库,简化了数据访问层的开发。
Hibernate 是一款开源 ORM(对象关系映射)框架,封装了 JDBC,允许以面向对象的方式操作数据库,简化了数据访问层的开发。通过映射机制,它可以自动处理对象与数据库表之间的转换,支持主流数据库,提高了代码的可移植性和可维护性。其核心接口包括 SessionFactory、Session 和 Transaction 等,通过它们可以执行数据库的 CRUD 操作。配置方面,需在项目中引入 Hibernate 及数据库驱动依赖,并创建 `hibernate.cfg.xml` 配置文件来设置数据库连接和 Hibernate 行为参数。
199 1
|
SQL XML 存储
Hibernate框架【五】——基本映射——多对多映射
Hibernate框架【五】——基本映射——多对多映射
349 0
|
数据库 Java 数据库连接
Struts 2 与 Hibernate 的完美邂逅:如何无缝集成两大框架,轻松玩转高效 CRUD 操作?
【8月更文挑战第31天】本文通过具体示例介绍了如何在 Struts 2 中整合 Hibernate,实现基本的 CRUD 操作。首先创建 Maven 项目并添加相关依赖,接着配置 Hibernate 并定义实体类及其映射文件。然后创建 DAO 接口及实现类处理数据库操作,再通过 Struts 2 的 Action 类处理用户请求。最后配置 `struts.xml` 文件并创建 JSP 页面展示用户列表及编辑表单。此示例展示了如何配置和使用这两个框架,使代码更加模块化和可维护。
447 0
|
SQL Java 数据库连接
Java从入门到精通:3.1.2深入学习Java EE技术——Hibernate与MyBatis等ORM框架的掌握
Java从入门到精通:3.1.2深入学习Java EE技术——Hibernate与MyBatis等ORM框架的掌握
192 1
|
Java 数据库连接 数据库
探索JPA生态:Hibernate与其他ORM框架的对比分析
【6月更文挑战第25天】**JPA标准下的Hibernate是流行的ORM实现,提供丰富功能如二级缓存和延迟加载,但其学习曲线较陡,性能优化复杂。相比如MyBatis,Hibernate的JPQL更面向对象,MyBatis则接近SQL。选择ORM需考虑项目需求和个人偏好。**
241 0
|
SQL Java 关系型数据库
数据库访问:什么是Hibernate框架?
【4月更文挑战第15天】Hibernate是开源ORM框架,将Java对象与数据库表映射,简化对象-关系映射,提升开发效率和性能。它自动化处理数据操作,支持多种数据库,自动生成SQL,提供配置选项和高级特性,减少手动SQL编写,便于切换数据库。
157 2

热门文章

最新文章