eclipse+maven搭建hibernate5测试环境

2024-01-07 16:18

本文主要是介绍eclipse+maven搭建hibernate5测试环境,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

eclipse+maven搭建hibernate5测试环境

  • 1环境
  • 2搭建
    • 2.1创建maven项目
    • 2.2配置maven依赖
    • 2.3配置hibernate持久化单元
    • 2.4.编写持久化类
    • 2.5.存储和查询测试Junit测试用例编写
  • 3.测试用例运行情况
    • 3.1.执行情况
    • 3.2.执行顺序
  • 4.相关知识
    • 4.1.Hibernate配置文件相关属性
    • 4.2.持久化类相关注解
    • 4.3.JUnit 4 相关注解
  • 5.常见问题及其解决

1环境

Eclipse: Luna Service Release 2 (4.4.2),Eclipse Java EE IDE for Web Developers.Maven:3.5.4

2搭建

2.1创建maven项目

选择Maven的Maven Project项目
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

2.2配置maven依赖

修改maven项目向导自动生成的pom.xml,添加依赖项

<dependencies><dependency><groupId>org.hibernate</groupId><artifactId>hibernate-entitymanager</artifactId><version>5.2.11.Final</version></dependency> <dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>5.1.32</version></dependency> <dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.11</version><scope>test</scope></dependency></dependencies>

2.3配置hibernate持久化单元

在路径src/main/resources/META-INF下新建persistence.xml配置文件

<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.0" xmlns="http://java.sun.com/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd "> <persistence-unit name="myPersistenceUnit"  transaction-type="RESOURCE_LOCAL"> <properties><property name="hibernate.dialect" value="org.hibernate.dialect.MySQL5InnoDBDialect" /><property name="hibernate.hbm2ddl.auto" value="create-drop" /> <property name="hibernate.connection.username" value="根据个人实际环境填写数据库连接的用户名" /><property name="hibernate.connection.password" value="根据个人实际环境填写数据库连接的密码" /><property name="hibernate.connection.url" value="jdbc:mysql://localhost:3306/jpa?useUnicode=true&amp;characterEncoding=UTF-8&amp;serverTimezone=UTC" /><property name="hibernate.format_sql" value="true" /> <property name="hibernate.use_sql_comments" value="true" /> <property name="hibernate.show_sql" value="true" /></properties></persistence-unit>
</persistence>

2.4.编写持久化类

在src/main/java中创建持久化类

package com.tyde.ht002.model;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Table;@Entity
@Table(name="tb_message")
public class Message {@Id@GeneratedValue(strategy=GenerationType.IDENTITY)private Long id;@Column(name="text")private String text;public String getText() {return text;}public void setText(String text) {this.text = text;}}

2.5.存储和查询测试Junit测试用例编写

在src/test/java中创建测试用例

import java.util.List;
import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.EntityTransaction;
import javax.persistence.Persistence;
import junit.framework.TestCase;
import org.junit.AfterClass;
import org.junit.BeforeClass;
import org.junit.FixMethodOrder;
import org.junit.Test;
import org.junit.runners.MethodSorters;
import com.tyde.ht002.model.Message;@FixMethodOrder(MethodSorters.NAME_ASCENDING)
public class TestHibernate {public static EntityManagerFactory emf;@BeforeClasspublic static void start(){System.out.println("start()");if(emf==null){emf = Persistence.createEntityManagerFactory("myPersistenceUnit"); }}
@AfterClasspublic static void stop(){System.out.println("stop()");if(emf!=null){emf.close(); }}@Testpublic void test001StoreMessage(){ System.out.println("test001StoreMessage()");EntityManager em = emf.createEntityManager();EntityTransaction tx = em.getTransaction();tx.begin();Message message =new Message();message.setText("hello world!");em.persist(message );tx.commit();em.close(); } @Testpublic void test002QueryMessage(){  System.out.println("test002QueryMessage()");EntityManager em = emf.createEntityManager();EntityTransaction tx = em.getTransaction();tx.begin();List<Message> messages = em.createQuery("select m from Message m").getResultList();TestCase.assertEquals(messages.size(),1);TestCase.assertEquals(messages.get(0).getText(),"hello world!");messages.get(0).setText("haha"); tx.commit();em.close();}}

3.测试用例运行情况

3.1.执行情况

两个测试用例都通过了
在这里插入图片描述

3.2.执行顺序

运行测试用例,查看控制台打印的方法和sql查询语句,可以看到顺序如下:
1、start()方法,实体管理器工厂的创建

Hibernate:     drop table if exists tb_message
Hibernate: create table tb_message (id bigint not null auto_increment,text varchar(255),primary key (id)) engine=InnoDB

2、test001StoreMessage()方法

Hibernate: /* insert com.tyde.ht002.model.Message*/ insert intotb_message(text) values(?)

3、test002QueryMessage()方法,查询,并修改

Hibernate: /* selectm fromMessage m */ selectmessage0_.id as id1_0_,message0_.text as text2_0_ fromtb_message message0_
Hibernate: /* updatecom.tyde.ht002.model.Message */ updatetb_message settext=? whereid=?

4、stop()方法,实体管理器工厂的关闭

Hibernate: drop table if exists tb_message

4.相关知识

4.1.Hibernate配置文件相关属性

属性描述相关值
hibernate.dialect数据库方言如:org.hibernate.dialect.MySQL5;org.hibernate.dialect.OracleDialect;org.hibernate.dialect.SQLServer2005Dialect;org.hibernate.dialect.SQLServer2008Dialect
hibernate.connection.username数据库连接用户名
hibernate.connection.password数据库连接密码
hibernate.connection.url数据库连接url路径
hibernate.format_sql格式化SQL
hibernate.use_sql_commentsSQL语句注释,可以查看SQL语句的起因。
hibernate.show_sql打印SQL语句,方便调试。
hibernate.hbm2ddl.auto数据库表生成方式create 每次加载hibernate会删除上一次的生成的表,再根据model类重新生成新表 ;
create-drop 每次加载hibernate根据model类生成表,但卸载后表就自动删除;
update第一次加载hibernate时会根据model类自动创建表,以后加载时自动更新;
validate每次加载时,验证表结构。

4.2.持久化类相关注解

注解描述
@Entity实体类,默认表的名字就是类名
@Table改变某些默认的映射规则
@Id声明主键
@GeneratedValue主键的生成策略。如:
GenerationType.IDENTITY使用数据库标识列来分配主键,以确保唯一性;
GenerationType.TABLE 使用数据库表来分配主键,以确保唯一性;
GenerationType.SEQUENCE使用数据库序列来分配主键,以确保唯一性;
GenerationType.AUTO根据具体数据库来选择前面几个策略的一种。
@Column属性与数据库字段的映射关系
@Transitent不需要映射的属性

4.3.JUnit 4 相关注解

5.常见问题及其解决

5.1.Junit问题
现象:junit报错junit.framework.AssertionFailedError: No tests found问题
原因:使用junit4.11版本,在写测试用例类时,使用了继承extends TestCase。junit3中使用继承,但junit4不用继承;
解决方式:extends TestCase junit3中使用,但是junit4中不要采用,去掉继承。ENCE使用数据库序列来分配主键,以确保唯一性;GenerationType.AUTO根据具体数据库来选择前面几个策略的一种。

5.2.Hibernate配置解析出错
现象:报错:对实体 “characterEncoding” 的引用必须以 ‘;’ 分隔符结尾
原因:在persistence.xml的文件中"&“未转义。
解决方式:在persistence.xml的文件中,我们需要将”&“做转义”&amp";如:

<property name="hibernate.connection.url" 
value="jdbc:mysql://localhost:3306/jpa?useUnicode=true&amp;characterEncoding=UTF-8&amp;serverTimezone=UTC" />

5.3.Mysql查询锁死
现象:测试用例一直执行不成功,通过navicate查询message表状态,标题栏一直显示“正在载入”

在这里插入图片描述
原因:表解锁在navicat for mysql中新建查询SHOW PROCESSLIST,查看当前任务列表,看到有很多waiting state的命令。

在这里插入图片描述
解决方式:结束所有操作当前表的进程Navicat中执行:kill + 进程号其中进程号即(SHOW PROCESSLIST查询结果表显示的ID)) 。

这篇关于eclipse+maven搭建hibernate5测试环境的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/580515

相关文章

利用Python快速搭建Markdown笔记发布系统

《利用Python快速搭建Markdown笔记发布系统》这篇文章主要为大家详细介绍了使用Python生态的成熟工具,在30分钟内搭建一个支持Markdown渲染、分类标签、全文搜索的私有化知识发布系统... 目录引言:为什么要自建知识博客一、技术选型:极简主义开发栈二、系统架构设计三、核心代码实现(分步解析

idea maven编译报错Java heap space的解决方法

《ideamaven编译报错Javaheapspace的解决方法》这篇文章主要为大家详细介绍了ideamaven编译报错Javaheapspace的相关解决方法,文中的示例代码讲解详细,感兴趣的... 目录1.增加 Maven 编译的堆内存2. 增加 IntelliJ IDEA 的堆内存3. 优化 Mave

使用Python实现快速搭建本地HTTP服务器

《使用Python实现快速搭建本地HTTP服务器》:本文主要介绍如何使用Python快速搭建本地HTTP服务器,轻松实现一键HTTP文件共享,同时结合二维码技术,让访问更简单,感兴趣的小伙伴可以了... 目录1. 概述2. 快速搭建 HTTP 文件共享服务2.1 核心思路2.2 代码实现2.3 代码解读3.

MySQL双主搭建+keepalived高可用的实现

《MySQL双主搭建+keepalived高可用的实现》本文主要介绍了MySQL双主搭建+keepalived高可用的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录一、测试环境准备二、主从搭建1.创建复制用户2.创建复制关系3.开启复制,确认复制是否成功4.同

一文教你如何将maven项目转成web项目

《一文教你如何将maven项目转成web项目》在软件开发过程中,有时我们需要将一个普通的Maven项目转换为Web项目,以便能够部署到Web容器中运行,本文将详细介绍如何通过简单的步骤完成这一转换过程... 目录准备工作步骤一:修改​​pom.XML​​1.1 添加​​packaging​​标签1.2 添加

使用DeepSeek搭建个人知识库(在笔记本电脑上)

《使用DeepSeek搭建个人知识库(在笔记本电脑上)》本文介绍了如何在笔记本电脑上使用DeepSeek和开源工具搭建个人知识库,通过安装DeepSeek和RAGFlow,并使用CherryStudi... 目录部署环境软件清单安装DeepSeek安装Cherry Studio安装RAGFlow设置知识库总

Linux搭建Mysql主从同步的教程

《Linux搭建Mysql主从同步的教程》:本文主要介绍Linux搭建Mysql主从同步的教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux搭建mysql主从同步1.启动mysql服务2.修改Mysql主库配置文件/etc/my.cnf3.重启主库my

国内环境搭建私有知识问答库踩坑记录(ollama+deepseek+ragflow)

《国内环境搭建私有知识问答库踩坑记录(ollama+deepseek+ragflow)》本文给大家利用deepseek模型搭建私有知识问答库的详细步骤和遇到的问题及解决办法,感兴趣的朋友一起看看吧... 目录1. 第1步大家在安装完ollama后,需要到系统环境变量中添加两个变量2. 第3步 “在cmd中

Maven pom.xml文件中build,plugin标签的使用小结

《Mavenpom.xml文件中build,plugin标签的使用小结》本文主要介绍了Mavenpom.xml文件中build,plugin标签的使用小结,文中通过示例代码介绍的非常详细,对大家的学... 目录<build> 标签Plugins插件<build> 标签<build> 标签是 pom.XML

IDEA与JDK、Maven安装配置完整步骤解析

《IDEA与JDK、Maven安装配置完整步骤解析》:本文主要介绍如何安装和配置IDE(IntelliJIDEA),包括IDE的安装步骤、JDK的下载与配置、Maven的安装与配置,以及如何在I... 目录1. IDE安装步骤2.配置操作步骤3. JDK配置下载JDK配置JDK环境变量4. Maven配置下