Hibernate实战之操作MySQL数据库(2024-1-8)
Hibernate实战之操作MySQL数据库 2024.1.8
- 前提环境(Java+MySQL+Navicat+VS Code)
- 1、Hibernate简介
- 1.1 了解HQL
- 2、MySQL数据库建表
- 2.1 编写SQL脚本
- 2.2 MySQL执行脚本
- 3、Java操作MySQL实例(Hibernate)
- 3.1 准备依赖的第三方jar包
- 3.2 了解MySQL数据库连接配置信息并配置XML文件
- 3.2.1 新建 hibernate.cfg.xml 文件
- 3.2.2 新建 Row.hbm.xml 文件
- 3.3 编写Java类实现数据库操作(Row+App)
- 3.3.1 Row.java
- 3.3.2 App.java(含main函数)
- 3.4 测试执行并利用Navicat查看数据库结果
- 3.4.1 新增
- 3.4.2 修改
- 3.4.3 查询
- 3.4.4 删除
- 4、小结
前提环境(Java+MySQL+Navicat+VS Code)
| |
| |
1、Hibernate简介
Hibernate是一个以LGPL(Lesser GNU Public License)许可证形式发布的开源项目,它可以直接提供相关支持,底层驱动可以随意切换数据库,快速简洁。使业务层与具体数据库分开,只针对Hibernate
进行开发,完成数据和对象的持久化。如果大家感兴趣想要深入了解,建议参考其官方文档和引导示例学习,如QuickStart和中文文档。
| |
| |
1.1 了解HQL
HQL是Hibernate Query Language
的缩写,它可以提供更加丰富灵活、更为强大的查询能力,HQL
更接近SQL
语句查询语法,对动态查询参数绑定提供了丰富的支持,提供了类似标准SQL
语句的查询方式,同时也提供了更加面向对象的封装。尤其在实体查询、更新、删除
方面,一些常见的用法示例如下:
from User user where user age=20;from User user where user age between 20 and 30;from User user where user age in(20,30);from User user where user name is null;from User user where user name like '%zx%';from User user where (user age%2)=1;from User user where user age=20 and user name like '%zx%';
此外,具体的语法学习可参考社区文档。
2、MySQL数据库建表
为了便于后续使用Java
代码操作MySQL
数据库,首先需要设计数据表结构,对表中的字段数量、类型、长度、别名、英文名均进行设置,编写好SQL脚本并在数据库中执行,之后在Navicat
或MySQL Workbench
中进行查看。
2.1 编写SQL脚本
字段名 | 字段类型 | 字段别名 |
---|---|---|
id | 文本 | 唯一标识 |
name | 文本 | 名称 |
date | 日期 | 日期 |
income | 小数 | 收入 |
针对上述表格中的create_Test.sql
脚本文件内容如下:
CREATE database if NOT EXISTS `my_db` default character set utf8mb4 collate utf8mb4_unicode_ci;
use `my_db`;
SET NAMES utf8mb4;CREATE TABLE if NOT EXISTS `test` (`id` CHAR(50) NOT NULL,`name` VARCHAR(50),`date` timestamp(6),`income` float4,PRIMARY KEY (id)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
2.2 MySQL执行脚本
第一步,打开MySQL Workbench
或Navicat
,新建MySQL
数据库连接,输入正确的用户名和密码后测试连接,连接成功后可以看到其中的数据库;
第二步,点击菜单中的新建查询,然后在编辑框中复制SQL
语句,当然也可以打开现有的SQL
文件,之后点击执行按钮即可查看到数据库和数据表已成功创建。
| |
3、Java操作MySQL实例(Hibernate)
下面具体以一个完整的Java
项目为例,来介绍如何利用Hibernate
对MySQL
进行增删改查等操作。整个过程可能有些繁琐,但都较为基本,按部就班操作即可,具体分为:(1)准备三方依赖jar
包;(2)了解MySQL
数据库连接配置信息;(3)配置XML
文件设置jdbc数据库连接MySQL
;(4)编写Java
类实现数据库操作;(5)测试执行查看效果。
3.1 准备依赖的第三方jar包
Java
项目代码所依赖的三方jar包名称如下,具体可以从Maven官方仓库下载。(注:如果使用Maven,也可在pom文件中引入)
antlr-2.7.7.jar
byte-buddy-1.11.22.jar
classmate-1.5.1.jar
dom4j-2.1.1.jar
hibernate-commons-annotations-5.0.4.Final.jar
hibernate-core-5.3.14.Final.jar
javax.persistence-api-2.2.jar
jboss-logging-3.3.3.Final.jar
jta-1.1.jar
mysql-connector-java-8.0.18.jar
|
|
3.2 了解MySQL数据库连接配置信息并配置XML文件
数据库名称 | ip地址 | 端口 | 用户名 | 密码 |
---|---|---|---|---|
my_db | localhost | 3306 | root | 123456 |
3.2.1 新建 hibernate.cfg.xml 文件
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC"-//Hibernate/Hibernate Configuration DTD 3.0//EN""http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<hibernate-configuration><session-factory><!-- 指定方言 --><property name="dialect">org.hibernate.dialect.MySQLDialect</property><!-- 链接数据库url --><property name="connection.url">jdbc:mysql://localhost:3306/my_db?useUnicode=true&characterEncoding=utf-8&serverTimezone=GMT%2B8</property><!-- 连接数据库的用户名 --><property name="connection.username">root</property><!-- 数据库的密码 --><property name="connection.password">123456</property><!-- 数据库驱动 --><property name="connection.driver_class">com.mysql.jdbc.Driver</property><!-- 显示sql语句 --><property name="show_sql">true</property><!-- 格式化sql语句 --><property name="format_sql">true</property><!-- 映射文件配置 --><mapping resource="com/Row.hbm.xml" /></session-factory>
</hibernate-configuration>
3.2.2 新建 Row.hbm.xml 文件
项目src
下的Row.hbm.xml
文件是对hibernate
对数据库my_db
中test
表做的映射配置,同时应注意与对应的数据表类放在同一目录(package包)下,因此在编写HQL
字符串语句时,需要从Row
中查询而非test
,实际执行时会从Row
映射到test
数据表哦!!!
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping><class name="com.Row" table="test"><id name="id" column="id"><!-- <generator class="org.hibernate.id.UUIDGenerator"/> --><generator class="uuid"/></id><property name="name" column="name"/><property name="date" column="date"/><property name="income" column="income"/></class>
</hibernate-mapping>
3.3 编写Java类实现数据库操作(Row+App)
编写Row.java
类作为对test
数据表中每行记录的抽象,编写App
类调用main函数连接数据库执行相应的操作实例。
3.3.1 Row.java
package com;import java.util.Date;
import javax.persistence.*;
import org.hibernate.annotations.GenericGenerator;@Entity
@Table
public class Row {//设置主键@Id //配置uuid,原本jpa是不支持uuid的,但借用hibernate的方法能够实现。@GeneratedValue(generator = "idGenerator")@GenericGenerator(name = "idGenerator", strategy = "org.hibernate.id.UUIDGenerator") // uuid@Column(name = "id", unique = true, nullable = false, length = 32)private String id;public String getId() {return id;}public void setId(String id) {this.id = id;}private String name;public String getName() {return name;}public void setName(String name) {this.name = name;}private Date date;public Date getDate() {return date;}public void setDate(Date date) {this.date = date;}private Float income;public Float getIncome() {return income;}public void setIncome(Float income) {this.income = income;}}
3.3.2 App.java(含main函数)
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
import org.hibernate.Session;
// import org.hibernate.id.UUIDHexGenerator;
import java.util.List;
import java.util.Date;import com.Row;public class App {// 一、插入数据(新增)public static void insertData(String name, int count){Configuration config = new Configuration().configure();// 创建Configuration对象并加载hibernate.cfg.xml配置文件SessionFactory sessionFactory = config.buildSessionFactory();// 获取SessionFactorySession session = sessionFactory.openSession();// 从sessionFactory 获取 SessionTransaction transaction = session.beginTransaction();// 事务开启for(int i=0;i<count;i++){Row row = new Row(); //uuid已经自动生成,无须手动添加row.setName(name);Date date = new Date();row.setDate(date);Float income = new Float((i+1) * count + 0.5);row.setIncome(income);Object res = session.save(row); // 将对象(Row)保存到表test中System.out.println("id:" + res);}transaction.commit(); // 事务提交session.close(); // 关闭session & sessionFactorysessionFactory.close();}// 二、根据条件删除数据库(删除)public static void deleteData(String condition){Configuration config = new Configuration().configure();// 创建Configuration对象并加载hibernate.cfg.xml配置文件SessionFactory sessionFactory = config.buildSessionFactory();// 获取SessionFactorySession session = sessionFactory.openSession();// 从sessionFactory 获取 Sessiontry{Transaction transaction = session.beginTransaction();String hql = "delete from Row where " + condition;int rowsAffected = session.createQuery(hql).executeUpdate(); System.out.println(rowsAffected + " rows affected.");transaction.commit();}catch(Exception e){System.out.println("出错: " + e.getMessage());e.printStackTrace();}finally{if (session != null)session.close(); // 关闭session & sessionFactoryif (sessionFactory != null)sessionFactory.close(); }}// 三、根据条件更新数据库(修改)public static void updateData(String condition){Configuration config = new Configuration().configure();// 创建Configuration对象并加载hibernate.cfg.xml配置文件SessionFactory sessionFactory = config.buildSessionFactory();// 获取SessionFactorySession session = sessionFactory.openSession();// 从sessionFactory 获取 Sessiontry{Transaction transaction = session.beginTransaction();String hql = "update Row " + condition;int rowsAffected = session.createQuery(hql).executeUpdate();System.out.print(rowsAffected + " rows affected.");transaction.commit();}catch(Exception e){System.out.println("出错: " + e.getMessage());e.printStackTrace();}finally{if (session != null)session.close(); // 关闭session & sessionFactoryif (sessionFactory != null)sessionFactory.close(); }}// 四、根据条件查询数据库(查询)public static void queryAllData(String condition){Configuration config = new Configuration().configure();// 创建Configuration对象并加载hibernate.cfg.xml配置文件SessionFactory sessionFactory = config.buildSessionFactory();// 获取SessionFactorySession session = sessionFactory.openSession();// 从sessionFactory 获取 Sessiontry{String hql = "from Row where " + condition;List<Row> results = session.createQuery(hql).list();if(results.size() == 0){System.out.println("找不到记录!");}else{for(Row row: results){System.out.println("编号:" + row.getId() + ", 名称:" + row.getName() + ", 日期:" + row.getDate() + ", 收入:" + row.getIncome());}}}catch(Exception e){System.out.println("出错: " + e.getMessage());e.printStackTrace();}finally{if (session != null)session.close(); // 关闭session & sessionFactoryif (sessionFactory != null)sessionFactory.close(); }}public static void main(String[] args) throws Exception {insertData("张三", 10);// queryAllData("1=1"); // "1=1" "id = '4028896c8cdd6d55018cdd6d56420002'"// updateData("set name = '12233330000' WHERE 1=1");// deleteData("1=1"); // name = 'jing_zhong'}
}
3.4 测试执行并利用Navicat查看数据库结果
分别对常用的四种增删改查操作来进行测试执行,VSCode
控制台和Navicat
数据库结果分别如下图所示。
3.4.1 新增
3.4.2 修改
3.4.3 查询
3.4.4 删除
4、小结
MySQL
数据库作为极其受欢迎的一种关系型数据库,一直以来以其简单快速的优点受到广大开发者/工程师的一致好评,尽管市面上流行着各种各样的数据库,无论是开源或是商用型数据库,从设计理念和查询执行速度和效率上或多或少会有不同,当然软件、数据库、连接驱动
版本也都在随之更新、迭代和升级 。
在平常的学习和工作中,熟练地运用数据库,学会利用SQL
或HQL
等脚本语言友好地与数据库交互,不仅是一种乐趣,而且也是除文件资源管理存储外的不二选择,对前端、后端工程师都会受益匪浅,提高效率,欢迎大家共同交流和探讨新技术或者遇到的问题,千千万万的开发者通力合作,一同解决技术问题,答疑解惑助力技术升级,共同营造良好生态,拥抱绿色未来最后希望小伙伴们都能够学有所成并学以致用哦!
相关文章:
Hibernate实战之操作MySQL数据库(2024-1-8)
Hibernate实战之操作MySQL数据库 2024.1.8 前提环境(JavaMySQLNavicatVS Code)1、Hibernate简介1.1 了解HQL 2、MySQL数据库建表2.1 编写SQL脚本2.2 MySQL执行脚本 3、Java操作MySQL实例(Hibernate)3.1 准备依赖的第三方jar包3.2 …...
【Spring Boot 3】【数据源】自定义JDBC多数据源
【Spring Boot 3】【数据源】自定义JDBC多数据源 背景介绍开发环境开发步骤及源码工程目录结构总结背景 软件开发是一门实践性科学,对大多数人来说,学习一种新技术不是一开始就去深究其原理,而是先从做出一个可工作的DEMO入手。但在我个人学习和工作经历中,每次学习新技术…...
番茄工作法
番茄工作法是一种时间管理方法,主要适用于专注工作。它的基本步骤包括: 设定一个25分钟的闹钟。默念三二一(321法则),开始全身心投入工作。用专注的状态高效工作25分钟,不允许走神。如果做到了步骤3&#…...
【uniapp】调用阿里云OCR图片识别文字:
文章目录 一、效果:二、实现: 一、效果: 二、实现: 【阿里官方】高精版OCR文字识别【最新版】-云市场-阿里云 <template><view class"container"><!-- 选择图片 --><button click"imageO…...
软考高级选择考哪个好?
📒软考高级总共5个科目,同样是高级证书,认可度也有区别! 大家一般在「信息系统项目管理师」✔️和「系统架构设计师」✔️二选一 1️⃣信息系统项目管理师 ❤️信息系统项目管理师也叫「高项」,考试内容主要是「项目管理」相关&am…...
在云服务器ECS上用Python写一个搜索引擎
在云服务器ECS上用Python写一个搜索引擎 一、场景介绍二、搜索引擎的组成2.1 网页的爬取及排序2.2 用户使用搜索引擎进行搜索 三、操作步骤3.1 环境准备3.2 安装Anaconda3.3 安装Streamlit3.4 下载搜索引擎代码3.5 运行搜索引擎 四、常见问题4.1 运行setup.py时可能的问题4.2 如…...
Python在智能手机芯片研发
Python在智能手机芯片研发中扮演着重要的角色。以下是几个方面的重要性: 快速原型设计:Python具有简洁易读的语法和丰富的第三方库,使工程师能够快速构建原型和进行快速迭代。这对于芯片研发来说,可以加快开发速度,减少…...
K8S学习指南(70)-K8S中的informa机制
引言 在 Kubernetes 集群中,Informer 是一种重要的机制,用于监控和处理集群中资源对象的变化。它是基于观察者模式设计的,允许开发者注册对某类资源对象的关注,并在对象发生变化时得到通知。本文将深入介绍 Kubernetes 中的 Info…...
「MCU」SD NAND芯片之国产新选择优秀
文章目录 前言 传统SD卡和可贴片SD卡 传统SD卡 可贴片SD卡 实际使用 总结 前言 随着目前时代的快速发展,即使是使用MCU的项目上也经常有大数据存储的需求。可以看到经常有小伙伴这样提问: 大家好,请问有没有SD卡芯片,可以…...
【QML COOK】- 002-添加一个图片
1. 编辑main.qml import QtQuickWindow {width: 800height: 800visible: truetitle: qsTr("Hello World")Image {anchors.fill: parentsource: "qrc:/Resources/Images/arrow.png"} }将Window的width和height都改成800,因为我们要添加的图片大…...
Java10:内部类
7 内部类(了解)7.1 成员内部类7.2 静态内部类7.3 局部内部类7.4 匿名内部类 2.3. 静态内部类2.4. Lambda表达式, 7 内部类(了解) 内部类:就是在一个类的内部再定义一个类。 分类: 成员内部类 静…...
PostgreSQL 支持的字段类型
PostgreSQL 支持多种字段类型,以下是 PostgreSQL 13 版本中支持的所有字段类型: 数值类型: smallint:小整数类型。integer:整数类型。bigint:大整数类型。decimal:精确小数类型。numeric&#x…...
npm报错error:03000086:digital envelope routines::initialization error
可能是因为node版本过高,与现在的项目不符合 这是降低node版本的命令,然后重新运行 npm install npm8.1.2 -g...
el-table 展开行表格,展开的内容高度可以变化时,导致的固定列错位的问题
问题描述 一个可展开的表格(列设置了type“expand”),并且展开后的内容高度可以变化,会导致后面所有行的固定列错位,图如下,展示行中是一个树形表格,默认不展示子级,点击树形表格的…...
python插入排序
插入排序(Insertion Sort)是一种简单直观的排序算法。它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。插入排序在实现上,通常使用in-place排序࿰…...
怎么将营业执照图片转为excel表格?(批量合并识别技巧)
一、为何要将营业执照转为excel表格? 1、方便管理:将营业执照转为excel格式,可以方便地进行管理和整理,快速查找需要的信息。 2、数据处理:Excel可以提供丰富的计算和数据分析功能,转化为excel后方便数据…...
关于java数组Arrays类
关于java数组Arrays类 前面的文章中,我们了解了数组创建方法等,我们本篇文章来了解一下数组的方法类Arrays,有了这个类,我们在日常写代码的时候就不不用自己去手动创建方法了😀。 Arrays类 数组的工具类java.util.A…...
LeetCode-58/709
1.最后一个单词的长度(58) 题目描述: 给你一个字符串 s,由若干单词组成,单词前后用一些空格字符隔开。返回字符串中 最后一个 单词的长度。 单词 是指仅由字母组成、不包含任何空格字符的最大子字符串。 思路&…...
linux 流量监控
linux 流量监控 Linux 网络流量监控利器 iftop命令详解及实战 https://blog.csdn.net/qq_50247813/article/details/134164093 iftop命令详解 https://www.cnblogs.com/gaoyuechen/p/17300017.html 1 ubuntu如何查看流量监控 Ubuntu是一种非常流行的Linux发行版,…...
AUTOSAR从入门到精通-漫谈autosar软件架构(八)
目录 前言 原理 AUTOSAR的方法论 AUTOSAR架构的优点 AUTOSAR 软件架构 1.应用层...
C#设计模式之单例模式
介绍 单例模式(Singleton)保证一个类仅有一个实例,并提供一个访问它的全局访问点。 单例模式的结构图如下所示: 使用单例模式的原因 对一些类来说,只有一个实例是很重要的。如何才能保证一个类只有一个实例并且这个…...
【源码预备】Calcite基础知识与概念:关系代数概念、查询优化、sql关键字执行顺序以及calcite基础概念
文章目录 一. 关系代数的基本知识二. 查询优化三. SQL语句的解析顺序1. FROM2. WHERE3. GROUP BY4. HAVING5. SELECT 四. Apache Calcite中的基本概念1. Adapter2. Calcite中的关系表达式2.1. 关系表达式例子2.2. 源码底层结构 3. Calcite的优化规则4. Calcite的Trait--算子物理…...
【Java 设计模式】23 种设计模式
文章目录 设计模式是什么计算机行业里的设计模式创建型模式(共 5 种)结构型模式(共 7 种)行为型模式(共 11 种) 总结 设计模式是什么 “每一个模式描述了一个在我们周围不断重复发生的问题,以及…...
ElasticSearch深度分页解决方案
一、前言 ElasticSearch是一个基于Lucene的搜索引擎,它支持复杂的全文搜索和实时数据分析。在实际应用中,我们经常需要对大量数据进行分页查询,但是传统的分页方式在处理大量数据时会遇到性能瓶颈。本文将介绍ElasticSearch分页工作原理、深…...
nginx下upstream模块详解
目录 一:介绍 二:特性介绍 一:介绍 Nginx的upstream模块用于定义后端服务器组,以及与这些服务器进行通信的方式。它是Nginx负载均衡功能的核心部分,允许将请求转发到多个后端服务器,并平衡负载。 在upst…...
基于ssm的双减后初小教育课外学习生活活动平台的设计与实现论文
双减后初小教育课外学习生活活动平台的设计与实现 摘 要 当下,正处于信息化的时代,许多行业顺应时代的变化,结合使用计算机技术向数字化、信息化建设迈进。以前学校对于课外学习活动信息的管理和控制,采用人工登记的方式保存相关…...
wblogic中间件配置数据源
配置数据源 1.服务-数据源-配置-新建 2.单机选一般数据源 3.选择源名称、jndi名称、数据库类型 4.选择驱动 5.下一步 6.输入连接串信息 参考: 格式二:jdbc:oracle:thin:<host>:<port>:<SID> 数据库名称配置的sid 7.测试配置ÿ…...
Java数据结构之装箱拆箱
装箱和拆箱 也叫装包拆包,装包是把那八种基本数据类型转换为它的包装类,拆包则相反 上面这俩种方式都是装包,下面是它的字节码文件 用到了Integer的ValueOf方法: 就是返回了一个Integer类的对象,把它的value属性设置成…...
各版本 操作系统 对 .NET Framework 与 .NET Core 支持
有两种类型的受支持版本:长期支持 (LTS) 版本和标准期限支持 (STS) 版本。 所有版本的质量都是一样的。 唯一的区别是支持的时间长短。 LTS 版本可获得为期三年的免费支持和补丁。 STS 版本可获得 18 个月的免费支持和修补程序。 有关详细信息,请参阅 .N…...
Golang 线程安全与 sync.Map
前言 线程安全通常是指在并发环境下,共享资源的访问被适当地管理,以防止竞争条件(race conditions)导致的数据不一致 Go语言中的线程安全可以通过多种方式实现 实现方式 互斥锁(Mutexes) Go的sync包提供…...
amh wordpress伪静态/成都网络推广运营公司
有人曾说,未来只有2种人,会Python的人和....不懂Python的小学生,虽有夸张,这也意味着Python越来越重要了,究竟这门语言厉害在哪里?以下为你总结了Python3宗“罪”! Python凭啥这么优秀…...
asp网站建设实录源码/国内最近发生的重大新闻
大家知道Android Activity在横竖屏切换的时候会重建以适应新的屏幕和环境 这是必然的 但是有时候容易忽视此引起的问题 如 在调用三方识别SDK的时候,他是横屏识别,你原Activity是竖屏,你若不处理,原Activity已有的数据就会被重建&…...
网站视频制作/sem培训班
转载于:https://www.cnblogs.com/hoobey/p/6501373.html...
网站字体规范/网络培训研修总结
ERP项目的成败关系企业未来的发展。ERP选型关系项目的成败,但很多由于企业对ERP项目了解甚少,在选型方面,做的不是很好。巅峰网ERP实施顾问,结合自己多年的工作经验,总结出企业在选型过程中几种常犯错误,希…...
定制开发一个网站多少钱/餐饮营销方案100例
时间可真快,感觉才刚来学校不久,竟然已经快两个星期了,现在脑子里除了ACM感觉别东西的都好陌生,哈哈,ACM也真是不可思议,作为人类发明的编程与算法的东西,它能够如此成熟,丰富&#…...
做yield网站多少钱/运营推广是做什么的
上一节我们讲了,DataGrid获取数据的一些用法,这一节讲DataGrid的分页 DataGrid将传递“当前页码”“每页条数”控制器获取参数之后交给BLL层处理逻辑和分页,返回总页数和当前页的数据最后交给DataGrid处理课外:从此次前端的处理速…...