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

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介: 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是一个非常牛的框架。建议多学习。


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


相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
XML 存储 缓存
Hibernate开发环境的简单搭建及常见错误(一)上
Hibernate开发环境的简单搭建及常见错误(一)
130 0
Hibernate开发环境的简单搭建及常见错误(一)上
|
安全 Java 应用服务中间件
Java 近期新闻:Hibernate 6.0、JobRunr 5.0、JHipster 7.8.0、Spring CVEs、JReleaser 1.0-RC2
本期 Java 近期新闻综述内容涉及 JDK 19、Spring Boot、Spring CVEs、Apache Tomcat 点版本、Quarkus Tools for Visual Studio Code、Micronaut 3.4.1、JetBrains 加入 Micronaut 基金会、Open Liberty Paketo Liberty Buildpack、Hibernate 6.0、JobRunr 5.0、WildFly 26.1 Beta S2I 镜像、JReleaser 1.0-RC2、MicroStream 7.0-M2、JHipster 7.8.0、JMH 1.35。
782 0
|
17天前
|
SQL Java 数据库连接
jpa、hibernate、spring-data-jpa、jdbcTemplate
jpa、hibernate、spring-data-jpa、jdbcTemplate
|
4月前
|
存储 Java 数据库连接
Spring Boot 嵌入式服务器、Hibernate 关系和 Spring Data 全解析
Spring Boot 的嵌入式服务器功能是一项方便而强大的功能,它允许你在应用程序中直接运行 Web 服务器,无需将其部署到单独的独立 Web 服务器中。这使得开发、测试和部署 Web 应用程序变得容易,而且它还是轻量级的、易于启动和停止的,易于配置。
65 0
|
4月前
|
XML Java 数据库连接
Hibernate与Spring整合实践实例
Hibernate与Spring整合实践实例
40 0
|
7月前
|
存储 Oracle Java
[亲测可用]hibernate调用Oracle存储过程|Spring Data JPA调用Oracle存储过程方法
[亲测可用]hibernate调用Oracle存储过程|Spring Data JPA调用Oracle存储过程方法
|
9月前
|
Java 数据库连接 数据库
JAVA三大框架Struts、hibernate和spring的各自作用是什么?
JAVA三大框架Struts、hibernate和spring的各自作用是什么?
48 0
|
XML Java 关系型数据库
Spring 项目快速整合 Hibernate
前言 Hibernate 作为前些年广为流行的 ORM 框架,Spring 在诞生之初也进行了支持,并且抽象出一个 spring-orm 模块。
426 0
|
JavaScript Java 数据库连接
spring对hibernate的集成中的回调(CallBack)机制
spring对hibernate的集成中的回调(CallBack)机制
166 0
spring对hibernate的集成中的回调(CallBack)机制
|
Java 数据库连接 API
Spring整合Hibernate JPA
Spring整合Hibernate JPA
79 0