Java面经之MySQL

[1]. Hibernate和MyBatis的区别?

Hibernate是一种全自动的对象关系映射(ORM)框架,可以通过操作Java对象来间接操作数据库,适合需求明确、业务固定的项目。

MyBatis是一种半自动化的持久层框架,可以通过XML文件或注解直接编写SQL语句,适合需求多变的互联网项目。

[2]. MySQL和Redis的区别?

MySQL是关系型 数据库,以表格的形式将数据存储在硬盘中,读取速度慢。Redis是非关系型数据库,以键值对的形式将数据存储在内存中,读取速度快。

MySQL支持分布式事务,可以保证数据的一致性,而Redis是单节点的,不支持分布式事务,在并发访问时可能会出现数据不一致的情况。

MySQL适用 于大规模数据存储和复杂查询等场景,Redis适用于高并发读写、数据缓存和实时计算等高性能场景。

[3]. MySQL表和视图的区别?

表是存储数据的实体 ,具有完整的结构和功能,可以进行插入更新删除 操作,而视图 基于表的查询结果,提供了一种逻辑上的访问方式,是一个虚拟表 ,不存储实际数据,只能进行查询操作。

[4]. MySQL事务的四大特性?

MySQL事务具有原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)、持久性(Durability),即ACID四大特性。其中,原子性、隔离性、持久性是 ,一致性是

原子性指的是事务中的所有操作要么全部执行成功并且对数据库产生了影响,要么全部失败回滚,并且对数据库没有任何影响。

一致性是指事务执行过程中涉及的操作结果必须满足数据库的约束和规则,保证数据库的完整性没有被破坏。

隔离性是指在并发场景中,事务之间是相互隔离、互相独立的,一个事务的执行不受其他事务的影响。

持久性是指一个事务一旦被提交,在数据库中的改变就是永久的,即使系统崩溃,这些改变也不会丢失。

相关推荐
无限进步_1 小时前
【C++】可变参数模板与emplace系列
java·c++·算法
逻辑羊驼1 小时前
VSCODE 连接 MySQL 数据库并执行当地SQL文件
数据库·mysql
.千余1 小时前
【Linux 】网络基础1
linux·运维·服务器·开发语言·网络·学习
小短腿的代码世界1 小时前
Qt低级网络编程与零拷贝技术在高频交易中的应用:从QTcpSocket到共享内存的全链路优化
开发语言·网络·qt
计算机安禾1 小时前
【c++面向对象编程】第28篇:new/delete vs malloc/free:C++中正确动态内存管理
开发语言·c++·算法
逐光老顽童1 小时前
Java 内存模型深度解析与 JVM 调优实战指南
java·架构
夜白宋1 小时前
【Mysql深入】二、事务
数据库·mysql
写了20年代码的老程序员1 小时前
Excel 导入导出为什么总是把后端逼成字段搬运工
java·excel
TechWayfarer1 小时前
IP归属地API实战指南:用IP数据云解析日志挖掘用户地域分布
大数据·开发语言·网络·python·tcp/ip
ChoSeitaku1 小时前
10.枚举_Record_密封类_debug_API文档_Object类_lombok_Junit
java·数据库·junit