深入了解 MySQL:从基础到高级特性

引言

在当今数字化时代,数据的存储和管理至关重要。MySQL 作为一款广泛使用的开源关系型数据库管理系统(RDBMS),凭借其高性能、可靠性和易用性,成为众多开发者和企业的首选。本文将详细介绍 MySQL 的基础概念、安装启动、基本操作命令以及高级特性,并给出丰富的命令示例,帮助你全面掌握 MySQL 的使用。

一、MySQL 基础概念

数据库

数据库就像是一个大容器,用于存储各种数据。在 MySQL 里,你可以创建多个不同的数据库,以此来组织和管理不同类型的数据,就像不同的文件夹存放不同类型的文件一样。

表是数据库中存储数据的基本结构,由行和列构成。每一列代表一个字段,规定了数据的类型和属性;每一行则代表一条记录,包含各个字段的具体值。可以把表想象成一个 Excel 表格,列就是表头,行就是具体的数据行。

字段

字段是表中的列,每个字段都有特定的数据类型,如整数、字符串、日期等,这些数据类型用于限制存储的数据格式,确保数据的一致性和准确性。

记录

记录是表中的行,它包含了表中各个字段的具体值,代表一个完整的数据实体。例如在一个员工信息表中,一条记录就可能包含某个员工的姓名、年龄、部门等具体信息。

二、MySQL 安装与启动

安装

MySQL 的安装过程会因操作系统的不同而有所差异。下面以 Ubuntu 系统为例,介绍具体的安装步骤:

sudo apt update
sudo apt install mysql-server

如果你使用的是 Windows 系统,可以从 MySQL 官方网站下载安装程序,然后按照安装向导的提示进行操作。

启动与停止

在 Ubuntu 系统中,你可以使用以下命令来启动、停止和重启 MySQL 服务,还能设置其开机自启:

# 启动 MySQL 服务
sudo systemctl start mysql
# 停止 MySQL 服务
sudo systemctl stop mysql
# 重启 MySQL 服务
sudo systemctl restart mysql
# 设置 MySQL 服务开机自启
sudo systemctl enable mysql

三、MySQL 基本操作命令

登录 MySQL

使用以下命令登录 MySQL 服务器,输入命令后会提示你输入 MySQL 用户的密码:

mysql -u root -p

其中,-u 用于指定用户名,这里的 root 是 MySQL 的超级用户;-p 表示需要输入密码。

数据库操作

创建数据库
CREATE DATABASE mydatabase;

此命令会创建一个名为 mydatabase 的数据库。

查看所有数据库
SHOW DATABASES;

执行该命令后,会列出 MySQL 服务器上的所有数据库。

使用数据库
USE mydatabase;

这个命令会将当前的操作上下文切换到 mydatabase 数据库,之后的操作都会针对该数据库进行。

删除数据库
DROP DATABASE mydatabase;

该命令会删除名为 mydatabase 的数据库,需要注意的是,删除后数据将无法恢复,请谨慎使用。

表操作

创建表
CREATE TABLE employees (id INT AUTO_INCREMENT PRIMARY KEY,name VARCHAR(100) NOT NULL,age INT,department VARCHAR(50)
);

此命令创建了一个名为 employees 的表,包含 idnameage 和 department 四个字段。id 字段是自增的主键,name 字段不能为空。

查看表结构
DESCRIBE employees;

执行该命令会显示 employees 表的详细结构,包括字段名、数据类型、是否允许为空等信息。

查看所有表
SHOW TABLES;

该命令会列出当前数据库中的所有表。

修改表结构
-- 添加字段
ALTER TABLE employees ADD COLUMN salary DECIMAL(10, 2);
-- 修改字段类型
ALTER TABLE employees MODIFY COLUMN age TINYINT;
-- 删除字段
ALTER TABLE employees DROP COLUMN department;
删除表
DROP TABLE employees;

该命令会删除 employees 表,删除后数据将无法恢复,请谨慎使用。

数据操作

插入数据
INSERT INTO employees (name, age, salary) VALUES ('John Doe', 30, 5000.00);

此命令向 employees 表中插入一条记录,包含 nameage 和 salary 三个字段的值。

查询数据
-- 查询所有记录
SELECT * FROM employees;
-- 查询指定字段
SELECT name, age FROM employees;
-- 条件查询
SELECT * FROM employees WHERE age > 25;
-- 排序查询
SELECT * FROM employees ORDER BY age DESC;
更新数据
UPDATE employees SET salary = 5500.00 WHERE name = 'John Doe';

此命令将 employees 表中 name 为 John Doe 的记录的 salary 字段更新为 5500.00。

删除数据
DELETE FROM employees WHERE age < 20;

该命令会删除 employees 表中 age 小于 20 的所有记录。

其他常用命令

创建用户
CREATE USER 'newuser'@'localhost' IDENTIFIED BY 'password';

此命令创建了一个名为 newuser 的用户,该用户只能从本地(localhost)登录,密码为 password

授予权限
GRANT ALL PRIVILEGES ON mydatabase.* TO 'newuser'@'localhost';

该命令将 mydatabase 数据库的所有权限授予 newuser 用户。

刷新权限
FLUSH PRIVILEGES;

在修改用户权限后,需要执行此命令使权限生效。

退出 MySQL
EXIT;

此命令用于退出 MySQL 命令行界面。

四、MySQL 高级特性

索引

索引是一种特殊的数据结构,用于提高数据库查询的速度。你可以在表的一个或多个字段上创建索引,MySQL 会根据索引快速定位符合条件的记录。

-- 创建索引
CREATE INDEX idx_name ON employees (name);
-- 删除索引
DROP INDEX idx_name ON employees;

事务

事务是一组不可分割的数据库操作序列,要么全部执行成功,要么全部失败回滚。在 MySQL 中,可以使用以下命令管理事务:

-- 开始事务
START TRANSACTION;
-- 执行一系列操作
INSERT INTO employees (name, age) VALUES ('Jane Smith', 25);
UPDATE employees SET age = 26 WHERE name = 'Jane Smith';
-- 提交事务
COMMIT;
-- 回滚事务
ROLLBACK;

存储过程

存储过程是一组预编译的 SQL 语句集合,可以在数据库中存储和重复使用。

-- 创建存储过程
DELIMITER //
CREATE PROCEDURE GetEmployeesByAge(IN min_age INT)
BEGINSELECT * FROM employees WHERE age >= min_age;
END //
DELIMITER ;-- 调用存储过程
CALL GetEmployeesByAge(25);

视图

视图是虚拟的表,它基于 SQL 查询语句的结果集。视图不实际存储数据,而是在查询时动态生成结果。

-- 创建视图
CREATE VIEW young_employees AS
SELECT * FROM employees WHERE age < 30;-- 查询视图
SELECT * FROM young_employees;

时光匆匆,一篇博客又到了结尾处啦。真心感谢每一位愿意花时间阅读我文字的朋友,希望你们每天都过得开开心心的,生活顺顺利利哦,咱们下次再通过文字‘相遇’呀。

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

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

相关文章

2025年中国AI大模型综合排名及分析

&#xff08;基于2025年1月-2月多机构测评数据整合&#xff09; 一、综合排名与核心能力对比 根据SuperCLUE、艾媒咨询等机构最新评测数据&#xff08;截至2025年2月&#xff09;&#xff0c;中国主流AI大模型在综合性能、垂直场景适配性、成本效率等维度表现如下&#xff…

【ISO 14229-1:2023 UDS诊断全量测试用例清单系列:第三节】

ISO 14229-1:2023 UDS诊断服务测试用例全解析&#xff08;安全访问0x27服务&#xff09; 作者&#xff1a;车端域控测试工程师 更新日期&#xff1a;2025-02-12 关键词&#xff1a;UDS安全访问、0x27服务、ISO 14229-1:2023、ECU安全验证 一、服务概述 安全访问服务&#xff0…

深度剖析观察者模式:从理论到实战的Java实现

在软件设计中&#xff0c;观察者模式&#xff08;Observer Pattern&#xff09; 是一种高频使用的行为型设计模式&#xff0c;它定义了对象之间一对多的依赖关系&#xff0c;使得当一个对象状态改变时&#xff0c;其所有依赖对象&#xff08;观察者&#xff09;会自动收到通知并…

ComfyUI流程图生图原理详解

一、引言 ComfyUI 是一款功能强大的工具&#xff0c;在图像生成等领域有着广泛应用。本文补充一点ComfyUI 的安装与配置过程遇到的问题&#xff0c;并深入剖析图生图过程及相关参数&#xff0c;帮助读者快速入门并深入理解其原理。 二、ComfyUI 的安装与配置中遇到的问题 &a…

无人机遥感图像拼接及处理实践技术:生态环境监测、农业、林业等领域,结合图像拼接与处理技术,能够帮助我们更高效地进行地表空间要素的动态监测与分析

近年来&#xff0c;无人机技术在遥感领域的应用越来越广泛&#xff0c;尤其是在生态环境监测、农业、林业等领域&#xff0c;无人机遥感图像的处理与分析成为了科研和业务化工作中的重要环节。通过无人机获取的高分辨率影像数据&#xff0c;结合图像拼接与处理技术&#xff0c;…

web渗透测试之反弹shell SSRF结合redis结合伪协议 redis 未授权访问漏洞

目录 未授权访问漏洞利用:redis 反弹shell 漏洞原因就是&#xff1a; 反弹shell利用方式 反弹shell指的是什么 : 反弹shell的前提条件 步骤: redis未授权访问的三种利用手段反弹shell 利用定时任务反弹shell 攻击主机下设置 写入 webshell 步骤 利用公钥认证写入ro…

Conda 包管理:高效安装、更新和删除软件包

Conda 包管理&#xff1a;高效安装、更新和删除软件包 1. 引言 在使用 Anaconda 进行 Python 开发时&#xff0c;包管理是日常操作的核心内容。Conda 提供了一整套高效的工具来管理 Python 环境中的软件包&#xff0c;避免了版本冲突&#xff0c;并确保了环境的一致性。 本篇…

【Vue】打包vue3+vite项目发布到github page的完整过程

文章目录 第一步&#xff1a;打包第二步&#xff1a;github仓库设置第三步&#xff1a;安装插件gh-pages第四步&#xff1a;两个配置第五步&#xff1a;上传github其他问题1. 路由2.待补充 参考文章&#xff1a; 环境&#xff1a; vue3vite windows11&#xff08;使用终端即可&…

Win32/C++ 字符串操作实用工具

CStrUtils.h #pragma once#include <string> #include <vector> #include <windows.h> #include <tchar.h>#ifdef _UNICODE using _tstring std::wstring; #else using _tstring std::string; #endif// 字符串转换实用工具 namespace CStrUtils {//…

认购期权卖出相当于平仓吗?

财顺小编本文主要介绍认购期权卖出相当于平仓吗&#xff1f;认购期权卖出并不直接等同于平仓&#xff0c;但卖出认购期权可以是平仓操作的一部分。 认购期权卖出相当于平仓吗&#xff1f; 一、认购期权卖出的含义 卖出认购期权是指投资者作为期权卖方&#xff0c;将认购期权合…

C++ 学习之旅:环境搭建

C 学习之旅&#xff1a;环境搭建 在开启 C 学习的征程时&#xff0c;搭建好开发环境是关键的第一步。这篇博客将详细记录我在 C 环境搭建过程中的学习与实践&#xff0c;为了更直观展示操作步骤&#xff0c;还会添加相关操作图片描述。 一、了解 C 语言 在正式搭建环境前&am…

【C++前缀和】1074. 元素和为目标值的子矩阵数量|2189

本文涉及的基础知识点 C算法&#xff1a;前缀和、前缀乘积、前缀异或的原理、源码及测试用例 包括课程视频 LeetCode1074. 元素和为目标值的子矩阵数量 给出矩阵 matrix 和目标值 target&#xff0c;返回元素总和等于目标值的非空子矩阵的数量。 子矩阵 x1, y1, x2, y2 是满…

HTTP/2 由来及特性

HTTP/2 的由来 HTTP/1.x 的局限性 性能瓶颈 队头阻塞问题&#xff1a;在HTTP/1.x中&#xff0c;一个TCP连接在同一时间只能处理一个请求&#xff0c;后续请求必须等待前面的请求处理完成并收到响应后才能被处理。例如&#xff0c;当一个页面有多个资源&#xff08;如图片、脚…

package.json 文件配置

创建 Node.js 的配置文件 package.json npm init -y package.json 文件配置说明 配置说明示例name指定项目的名称&#xff0c;必须是小写字母&#xff0c;可以包含字母、数字、连字符&#xff08;-&#xff09;或下划线&#xff08;_&#xff09;&#xff0c;不能有特殊字符…

Leetcode1728:猫和老鼠 II

题目描述&#xff1a; 一只猫和一只老鼠在玩一个叫做猫和老鼠的游戏。 它们所处的环境设定是一个 rows x cols 的方格 grid &#xff0c;其中每个格子可能是一堵墙、一块地板、一位玩家&#xff08;猫或者老鼠&#xff09;或者食物。 玩家由字符 C &#xff08;代表猫&#…

【安当产品应用案例100集】037-强化OpenVPN安全防线的卓越之选——安当ASP身份认证系统

在当前数字化时代&#xff0c;网络安全已成为企业发展的重要组成部分。对于使用OpenVPN的企业而言&#xff0c;确保远程访问的安全性尤为重要。安当ASP身份认证系统凭借其强大的功能和便捷的集成方式&#xff0c;为OpenVPN的二次登录认证提供了理想的解决方案&#xff0c;特别是…

基于进化式大语言模型的下一代漏洞挖掘范式:智能对抗与自适应攻防体系

摘要 本文提出了一种基于进化式大语言模型(Evolutionary LLM)的智能漏洞挖掘框架,突破了传统静态分析的局限,构建了具备对抗性思维的动态攻防体系。通过引入深度强化学习与多模态感知机制,实现了漏洞挖掘过程的自适应进化,在RCE、SQLi、XXE等关键漏洞类型的检测中达到97…

2025年数据资产管理解决方案:资料合集,从基础知识到行业应用的全面解析

在数字化时代&#xff0c;数据已成为企业最宝贵的资产之一。如何有效地管理和利用这些数据&#xff0c;将其转化为实际的经济价值&#xff0c;已成为企业面临的重要课题。 本文将通过数据资产解决方案、数据资产行业报告白皮书、数据资产政策汇编、数据资产基础知识以及数据资…

【linux学习指南】模拟线程封装与智能指针shared_ptr

文章目录 &#x1f4dd;线程封装&#x1f309; Thread.hpp&#x1f309; Makefile &#x1f320;线程封装第一版&#x1f309; Makefile:&#x1f309;Main.cc&#x1f309; Thread.hpp: &#x1f320;线程封装第二版&#x1f309; Thread.hpp:&#x1f309; Main.cc &#x1f…

《深度LSTM vs 普通LSTM:训练与效果的深度剖析》

在深度学习领域&#xff0c;长短期记忆网络&#xff08;LSTM&#xff09;以其出色的处理序列数据能力而备受瞩目。而深度LSTM作为LSTM的扩展形式&#xff0c;与普通LSTM在训练和效果上存在着一些显著的不同。 训练方面 参数数量与计算量&#xff1a;普通LSTM通常只有一层或较少…