【MySQL面试题pro版-12】

MySQL是一个关系型数据库管理系统,由瑞典 MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的RDBMS (Relational Database Management System,关系数据库管理系统)应用软件之一。

MySQL有关权限的表都有哪几个?

MySQL中用于控制权限的表主要有六张表,它们分别是:

  1. user表:存储全局权限,即用户是否有权连接到MySQL服务器,以及用户密码等信息。它包含Host, User, Password等字段。
  2. db表:定义了用户对某个数据库的权限,例如是否允许用户访问某个特定的数据库。
  3. tables_priv表:定义了用户对某个数据库中的某个表的权限,比如选择、插入、更新和删除等操作。
  4. columns_priv表:定义了用户对某个表中的某个列的权限,可以更细粒度地控制用户访问数据的能力。
  5. procs_priv表:用来指定哪些用户可以执行哪些存储过程。
  6. proxies_priv表:用来管理代理用户及其相关权限。

这些权限表在MySQL数据库初始化时由mysql_install_db脚本创建,并存放于mysql数据库内。通过这些表,MySQL实现了灵活而强大的权限管理体系,确保了数据库的安全性和数据的完整性。

Mysqld的完整性约束包含哪些

数据完整性是指数据的精确和可靠性,分为以下四类:实体完整性:规定表的每一行在表中是惟一的实体。域完整 性:是指表中的列必须满足某种特定的数据类型约束,其中约束又包括取值范围、精度等规定。参照完整性:是指 两个表的主关键字和外关键字的数据应一致,保证了表之间的数据的一致性,防止了数据丢失或无意义的数据在数据 库中扩散。用户定义的完整性:用户定义的完整性即是针对某个特定关系数据库的约束条件,它反映某一具体应用 必须满足的语义要求。与表有关的约束:包括非空约束(NOT NULL)和表约束(PRIMARY KEY、foreign key、check、 UNIQUE等等) 。

数据库事务是什么

事务是作为一个单元的一组有序的数据库操作,事务的特性在Spring框架中可分为ACID。如果组中的所有操作都成 功,则认为事务成功,即使只有一个操作失败,事务也不成功。如果所有操作完成,事务则提交,其修改将作用于所 有其他数据库进程。如果一个操作失败,则事务将回滚,该事务所有操作的影响都将取消。

MyISAM Static和MyISAM Dynamic有什么区别?

在 MyISAM Static 上的所有字段有固定宽度。动态 MyISAM 表将具有像 TEXT,BLOB 等字段,以适应不同长度的数 据类型。MyISAM Static 在受损情况下更容易恢复。

为什么MyISAM不支持行锁,而InnoDB支持?

MyISAM不支持行锁而InnoDB支持,这主要是因为两者在设计上的不同以及InnoDB对高级事务功能的支持导致的。具体如下:

  • 设计差异:InnoDB是MySQL 5.5版本之后默认采用的事务型存储引擎,而MyISAM是MySQL老版本中默认的存储引擎。InnoDB的设计目标是提供更高的并发性能和数据完整性,而MyISAM更注重于性能优化和查询速度。
  • 锁机制:InnoDB支持行级锁和表级锁,默认为行级锁,这使得它在高并发写操作时能够提供更好的性能。相比之下,MyISAM只支持表级锁,这意味着任何一个写操作都可能锁定整张表,导致其他读写操作被阻塞,从而影响并发性能。
  • 事务支持:InnoDB支持事务处理,包括提交和回滚,这是通过其行锁机制实现的,它允许多个事务并发执行而不互相干扰。而MyISAM不支持事务,因此也就不需要行锁这一复杂的机制。

总的来说,由于InnoDB提供了更细粒度的锁定机制,它在处理并发事务时更为高效和安全。而MyISAM虽然在某些情况下可能更快,但它缺乏事务和行锁支持,在需要高并发处理的场景下可能不是最佳选择。

相关推荐
晋阳十二夜5 小时前
【压力测试之_Jmeter链接Oracle数据库链接】
数据库·oracle·压力测试
GDAL7 小时前
Node.js v22.5+ 官方 SQLite 模块全解析:从入门到实战
数据库·sqlite·node.js
DCTANT8 小时前
【原创】国产化适配-全量迁移MySQL数据到OpenGauss数据库
java·数据库·spring boot·mysql·opengauss
程序员岳焱9 小时前
Java 与 MySQL 性能优化:MySQL全文检索查询优化实践
后端·mysql·性能优化
喜欢敲代码的程序员10 小时前
SpringBoot+Mybatis+MySQL+Vue+ElementUI前后端分离版:项目搭建(一)
spring boot·mysql·elementui·vue·mybatis
AI、少年郎10 小时前
Oracle 进阶语法实战:从多维分析到数据清洗的深度应用(第四课)
数据库·oracle
赤橙红的黄10 小时前
自定义线程池-实现任务0丢失的处理策略
数据库·spring
钢铁男儿10 小时前
C# 委托(调用带引用参数的委托)
java·mysql·c#
叁沐10 小时前
MySQL 02 日志系统:一条SQL更新语句是如何执行的?
mysql
DataGear10 小时前
如何在DataGear 5.4.1 中快速制作SQL服务端分页的数据表格看板
javascript·数据库·sql·信息可视化·数据分析·echarts·数据可视化