MySQL数据库面试知识点

1、数据库基础:

MySQL是一个开源的关系型数据库管理系统,用于存储、管理和检索数据。它支持多种存储引擎,包括InnoDB、MyISAM等。MySQL是由瑞典公司MySQL AB开发,后来被Sun Microsystems收购,最终被甲骨文公司(Oracle Corporation)收购。MySQL是一个广泛应用于Web开发的数据库系统,它可以与许多编程语言(如PHP、Python、Java等)配合使用,同时也是许多流行的内容管理系统(如WordPress、Drupal、Joomla等)的基础。

2、数据库架构:

MySQL主要有两种架构选择:一种是传统的关系型数据库架构,另一种是分布式数据库架构。在关系型数据库架构中,数据被存储在表格中,表格由行和列组成,每行表示一条记录,每列表示一个属性。这种架构适用于大量数据的存储和检索,但并发访问控制和事务处理等方面需要一些复杂的设置。在分布式数据库架构中,数据被分散到多个节点上,每个节点可以独立处理和存储数据,这种架构适用于超大规模数据的存储和处理,但需要更加复杂的技术和设计。

3、表关联:

在MySQL中,可以使用JOIN来关联多个表。JOIN主要有三种类型:内连接(INNER JOIN)、左连接(LEFT JOIN)和右连接(RIGHT JOIN)。内连接返回两个表中匹配的行;左连接返回左表中的所有行,右连接返回右表中的所有行。具体使用哪种JOIN取决于查询需求和数据表关系。

4、索引:

索引是MySQL中一个重要的概念,用于加快查询速度。索引类似于书籍的目录,可以快速定位到数据表中的某一行或某一列。MySQL支持多种索引类型,包括B-tree索引、哈希索引、全文索引等。其中B-tree索引是常用的索引类型,它使用B-tree数据结构来存储索引数据,可以支持非常高效的查找和排序操作。

5、SQL查询优化:

SQL查询优化是提高MySQL性能的关键之一。优化SQL查询的方法有很多种,包括选择合适的数据类型、使用索引、避免使用SELECT *、使用LIMIT和OFFSET等。此外,MySQL也提供了一些查询优化工具和技术,如慢查询日志、性能模式等。

6、数据类型:

MySQL支持多种数据类型,包括整型、浮点型、字符串类型、日期和时间类型等。其中整型包括tinyint、smallint、mediumint、int和bigint等;浮点型包括float和double等;字符串类型包括char、varchar、text等;日期和时间类型包括date、time、datetime和timestamp等。不同的数据类型适用于不同的场景,需要根据实际需求选择合适的数据类型。

7、存储过程和函数:

MySQL支持存储过程和函数。存储过程是一组SQL语句的集合,可以接受参数并返回结果,它可以在数据库中进行一些复杂的操作。函数则是用来执行一些特定的计算或操作,并返回结果。使用存储过程和函数可以提高代码重用率和执行效率。

8、事务处理:

事务是MySQL中一个重要的概念,它是一组必须全部执行或全部不执行的SQL语句集合。事务处理可以确保数据的一致性和完整性,防止数据出现不一致的情况。MySQL中的事务处理主要有两种隔离级别:读未提交(Read uncommitted)和读已提交(Read committed)。读未提交级别可以读取其他事务未提交的数据,而读已提交级别则只能读取已经提交的事务数据。

9、数据库备份和恢复:

数据库备份是保证数据安全的重要措施之一。MySQL支持多种备份方式,包括物理备份和逻辑备份。物理备份是将整个数据库文件直接复制出来进行备份,逻辑备份则是将数据库中的数据以SQL语句的形式导出并保存。如果数据库出现问题,可以使用备份文件进行恢复。

10、数据安全性:

为了保证MySQL数据库的安全性,可以采取多种措施,如使用强密码、禁用远程访问、限制IP访问等。MySQL也提供了一些安全特性,如访问控制列表(Access Control Lists)、加密(Encryption)等。

11、MySQL性能调优:

MySQL性能调优主要包括调整查询性能、内存使用情况、CPU使用情况等方面的优化。查询性能优化可以通过优化SQL语句、使用索引等方式实现;内存使用情况可以通过调整缓存参数、连接数等方式进行优化;CPU使用情况可以通过调整线程池参数等方式进行优化。

12、数据库扩展性:

当数据库无法处理日益增长的数据量时,需要考虑数据库的扩展性。扩展性是指数据库系统在面对不断增长的数据量和复杂度时,能够平滑地扩展其性能和处理能力的能力。MySQL提供了多种扩展方案,包括分表分库(Sharding)、主从复制(Master-Slave Replication)、集群(Clustering)等。分表分库是将一个大表拆分成多个小表,分别存储在不同的数据库或服务器上,以减轻单个数据库

13、MySQL主从数据库

如何搭建MySQL主从数据库是MySQL中常见的一种高可用性和可扩展性的架构模式,通过主从复制技术实现数据同步,提供读写分离、备份恢复、负载均衡等功能。下面是一个简单的MySQL主从数据库搭建的步骤:

1.准备两台服务器,分别安装MySQL数据库。

2.在其中一台服务器上创建主库,并设置一个唯一的随机密码(例如root密码),启动主库。

3.在另一台服务器上创建从库,并启动从库。

4.登录主库,创建一张表用来记录主库的binlog位置。

CREATE TABLE master.binlog_info (    
id INT NOT NULL AUTO_INCREMENT,  log_name VARCHAR(255) NOT NULL,    pos INT NOT NULL,    PRIMARY KEY (id));

5.登录从库,修改从库的配置文件(my.cnf或my.ini),添加以下配置:

server-id = 2  # 从库的唯一标识,每个从库的server-id必须唯一
relay-log = mysql-relay-bin  # 从库的relay log名称,与主库的binlog名称相同
relay-log-index = mysql-bin.000001  # 从库的relay log索引文件名,与主库的binlog文件名相同
relay-log-name = mysql-relay-bin  # 从库的relay log名称,与主库的主库binlog名称相同
log-bin = mysql-bin  # 从库的binlog名称,与主库的binlog名称相同

6.重启从库。

7.在主库上执行以下语句,开启主库的binlog功能:

SET GLOBAL binlog_format = 'ROW';  # 行级日志格式
SET GLOBAL sync_binlog = 1;  # 每次事务提交后立即将binlog写入磁盘

8.在主库上创建一个用于复制的用户,并为该用户授予适当的权限。

9.在从库上执行以下语句,设置从库连接到主库的用户名和密码:

CHANGE MASTER TO MASTER_USER='username', MASTER_PASSWORD='password', MASTER_LOG_FILE='mysql-bin.000001', MASTER_LOG_POS=0;  # 'username''password'分别为主库连接用户名和密码,'mysql-bin.000001'0分别为主库当前的binlog文件名和位置

10.在从库上启动slave服务:

START SLAVE;

11.在主库上执行以下语句,开始向从库复制数据:

FLUSH TABLES WITH READ LOCK;  # 锁定主库上的所有表,防止数据被修改

14、MySQL如何实现读写分离

MySQL实现读写分离的主要方法是使用主从复制(Master-Slave Replication)或称为复制(Replication)。这里是一种基本的实现方式:
1.配置主服务器(Master):确保MySQL已安装并运行。登录到MySQL控制台,并执行

GRANT REPLICATION SLAVE ON *.* TO 'replication_user'@'%' IDENTIFIED BY 'password';

,其中’replication_user’是用于复制的用户名,'password’是该用户的密码。创建一个用于复制的MySQL用户,并赋予上述权限。在主服务器的配置文件(通常是my.cnf或my.ini)中添加以下配置:

 ini`[mysqld]    server-id=1    log_bin=mysql-bin    binlog_do_db=your_database_name    

请确保替换your_database_name为实际的数据库名。

2.配置从服务器(Slave):确保MySQL已安装并运行。登录到MySQL控制台,并执行以下命令,设置从服务器连接到主服务器的信息和复制的起始位置:

CHANGE MASTER TO    MASTER_HOST='master_ip_address',    MASTER_USER='replication_user',    MASTER_PASSWORD='password',    MASTER_LOG_FILE='binlog_file_on_master',    MASTER_LOG_POS=0;`

请确保替换master_ip_address为主服务器的IP地址,replication_user和password为上一步中创建的复制用户的用户名和密码,binlog_file_on_master为主服务器当前的二进制日志文件名。启动从服务器:START SLAVE;

3.测试读写分离:在应用程序中,可以将读操作和写操作分开。读操作指向从服务器,而写操作指向主服务器。这样可以分摊数据库的负载,并提高系统的性能。在主服务器上进行写操作,然后观察从服务器是否同步这些更改。可以使用以下命令检查从服务器的状态:
SHOW SLAVE STATUS\G;。从服务器的Seconds_Behind_Master字段应显示为0,表示主从服务器之间的复制是实时的。

4.高可用性和故障转移:为了提高系统的可用性,可以在另一个从服务器上创建一个与主服务器保持同步的备份。如果主服务器发生故障,可以临时将其中一个从服务器提升为主服务器,而其他从服务器可以继续提供读服务。可以使用诸如MHA(Master High Availability)等工具来自动化故障转移过程。以上是一个基本的MySQL读写分离配置示例。根据实际需求和环境,可能需要进行额外的配置和优化。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/643219.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

4G物联网LED智慧路灯杆显示屏产品介绍

4GLED显示屏是一种具有4G网络连接功能的LED显示屏。它可以通过4G网络连接到互联网,实现远程管理和控制,方便进行内容更新和管理。同时,4GLED显示屏具有高亮度、高清晰度和高对比度的特点,可以提供清晰明亮的图像和视频展示效果。它…

stm32产品架构

文章目录 前言一、pandas是什么?二、使用步骤 1.引入库2.读入数据 总结 前言 起因是我在看野火的ucosiii,然后他是基于i.mx芯片。然后我就很疑惑i.mx是什么芯片,看了下好像是ARM-M7(或者叫ARMCM7)架构的芯片。然后我又疑惑ARM-M7又是什么架…

omron adept控制器维修SmartController EX

欧姆龙机器人adept运动控制器维修SmartController EX 19300-000 维修范围:姆龙机器人;码垛机器人;搬运机器人;焊机机器人;变位机等。 Adept Viper s650/s850用于装配、物料搬运、包装和机械装卸,循环周期短…

二进制?十进制!(C语言刷题)(位运算)

专栏:https://blog.csdn.net/2301_79293429/category_12545690.html 题目描述 给定两个十进制整数 : A,B 你需要把它们的二进制形式以十进制的运算法则相加输出结果。 例如: A3,B2的时候,A 的二进制表示是 : 11 , B 的二进制表示是 10 ,…

物流实时数仓——概述与准备工作

目录 一、架构设计与技术栈 (一)数仓架构设计 (二)所用技术栈 (三)最终效果 二、关于离线与实时的相关概念 三、实时数仓设计思路 一、架构设计与技术栈 (一)数仓架构设计 (二)所用技术栈 Hadoop 3.3.4 Zookeeper 3.7.1 Kafka 3.3.1 Hbase 2.4.11 Redis 6.0.8 Flink 1.17…

mysqldump添加从库或者重新同步从库

一、GTID添加从库的方法 1.如果master所有的binlog还在,安装slave后,直接change master 到master 原理是直接获取master所有的gtid并执行 优点是简单 缺点是如果binlog太多,数据完全同步需要的时间较长,并且需要master一开始就启…

Leetcode2806. 取整购买后的账户余额

Every day a Leetcode 题目来源:2806. 取整购买后的账户余额 解法1:数学 题目要求为将 purchaseAmount 四舍五入到最近的 10 的倍数作为 roundedAmount,计算 100−roundedAmount 的值并返回。 分类讨论即可。 代码: /** lc…

机器学习实验3——支持向量机分类鸢尾花

文章目录 🧡🧡实验内容🧡🧡🧡🧡数据预处理🧡🧡代码认识数据相关性分析径向可视化各个特征之间的关系图 🧡🧡支持向量机SVM求解🧡🧡直觉…

CentOS:nohup后台运行jar文件包程序

1、java -jar XXX.jar 特点:当前ssh窗口被锁定,可按CTRL C打断程序运行,或直接关闭窗口,程序退出 那如何让窗口不锁定? 2、java -jar XXX.jar & &代表在后台运行。 特定:当前ssh窗口不被锁定&…

Parade Series - Android Studio

硬件支持 CPU i7 RAM 16Gb -------------- ------- Java 3Gb Android 33GbJava Enviroment C:\ ├─ Java │ ├─ jdk1.8.0_181 │ ├─ jre1.8.0_181 │ ├─ maven-3.8.5 │ └─ gradle-6.5 └─ Cache├─ gr…

世微AP2915宽电压无MOS管切换双色灯性价比方案

1:产品描述 AP2915 是一款可以一路灯串切换两路灯串的降压恒流驱动器,高效率、外围简单、内置功率管,适用于 5-100V 输入的高精度降压 LED 恒流驱动芯片。内置功率管输出功率可达 12W,电流 1.2A。AP2915 一路灯亮切换两路灯亮,其…

【第十五课】数据结构:堆 (“堆”的介绍+主要操作 / acwing-838堆排序 / c++代码 )

目录 关于堆的一些知识的回顾 数据结构:堆的特点 "down" 和 "up":维护堆的性质 down up 数据结构:堆的主要操作 acwing-838堆排序 代码如下 时间复杂度分析 确实是在写的过程中频繁回顾了很多关于树的知识&…

使用ElEment组件实现vue表单校验空值

1.绑定表单组件数组rules 2.在data域中设定组件rules 3.设定调用方法函数 提交校验 取消: 测试页面 提交空值 失去焦点 取消重置 提交后重置

Studio One 6 mac 6.5.2 激活版 数字音乐编曲创作

PreSonus Studio One是PreSonus出品的一款功能强大的音乐创作软件。主要为用户提供音乐创作、录音、编辑、制作等功能。它可以让你创造音乐,无限的轨道,无限的MIDI和乐器轨道,虚拟乐器和效果通道,这些都是强大和完美的。 软件下载…

机器学习西瓜书之对数几率回归

算法原理 在线性模型的基础上增加一个激活函数用于映射。 知识预备 信息论 用概率论和随机过程为基本研究工具,研究广义通信系统的整个过程。常见的有无损压缩、有数据压缩等。 自信息: I ( X ) − log ⁡ b p ( x ) I(X)-\log_bp(x) I(X)−logb​p…

【Maven】-- 打包添加时间戳的两种方法

一、需求 在执行 mvn clean package -Dmaven.test.skiptrue 后,生成的 jar 包带有自定义系统时间。 二、实现 方法一:使用自带属性(不推荐) 使用系统时间戳,但有一个问题,就是默认使用 UTC0 的时区。举例…

单片机11-13

目录 蜂鸣器 蜂鸣器播放按键提示音 蜂鸣器播放音乐 AT24C02(IIC)总线 AT24C02数据存储 AT24C02秒表(定时器扫描按键) DS18B20温度传感器(单总线) 温度显示 温度报警器 蜂鸣器 蜂鸣器播放按键提示音…

网络安全B模块(笔记详解)- 文件MD5校验

1.进入虚拟机操作系统:CentOS 6.8中的/root目录,找到test.txt文件,并使用md5sum工具来计算出该文件的md5值,并将计算该文件md5的命令的字符串作为Flag进行提交; 2.进入虚拟机操作系统:CentOS 6.8中的/root目录,找到test.txt文件,并使用md5sum校验工具来计算出该文件的…

一款相对比较强大的国产ARM单片机HC32F4A0

已经用了3年的HC32F4A0,已经对它比较熟悉了,与STM32相比它的外设使用这些的确是挺大大,不像GD32一类的单片机很多都能兼容STM32。用久了之后就更喜欢用HC32F4A0,功能强大,外设使用灵活,用点向FPGA靠拢的感觉…

安全认证机制之JWT

文章目录 前言一、JWT是什么二、为什么要用JWT三、JWT的组成四、JWT的应用场景总结 前言 在我们实际开发中会接触到很多安全认证机制,诸如HTTP Basic Auth、OAuth、Cookie-session Auth、Token Auth、JWT等等,今天我们就来聊一下基于JWT的Token认证机制。…