MySQL 数据库基础详细解释和示例

server/2025/3/1 1:43:21/

目录

数据库操作关键字

CREATE DATABASE

USE

DROP DATABASE

表操作关键字

CREATE TABLE

DESCRIBE

ALTER TABLE

DROP TABLE

数据操作关键字

INSERT INTO

SELECT

UPDATE

DELETE

索引操作关键字

CREATE INDEX

DROP INDEX

事务处理关键字

START TRANSACTION

COMMIT

ROLLBACK

多表操作关键字

JOIN


数据库操作关键字

CREATE DATABASE
  • 解释:用于在 MySQL 中创建一个新的数据库数据库是存储表、视图、存储过程等数据库对象的容器。
  • 示例
CREATE DATABASE school_db;

此语句创建了一个名为 school_db 的数据库

USE
  • 解释:用于指定当前要使用的数据库。在执行对表的操作之前,需要先选择相应的数据库
  • 示例
USE school_db;

执行此语句后,后续的表操作将在 school_db 数据库中进行。

DROP DATABASE
  • 解释:用于删除指定的数据库。删除后,该数据库及其包含的所有对象(如表、视图等)将被永久删除,操作需谨慎。
  • 示例
DROP DATABASE school_db;

表操作关键字

CREATE TABLE
  • 解释:用于创建新的表。在定义表时,需要指定表名和各个列的名称、数据类型以及列的约束条件。
  • 示例
CREATE TABLE students (student_id INT AUTO_INCREMENT PRIMARY KEY,student_name VARCHAR(100) NOT NULL,age INT,gender CHAR(1),class_id INT
);
  • AUTO_INCREMENT:为 student_id 列设置自动递增属性,插入新记录时该列会自动生成唯一的递增整数。
  • PRIMARY KEY:将 student_id 列设置为主键,保证每一行记录的 student_id 唯一且不为 NULL
  • NOT NULL:表示 student_name 列的值不能为空。
DESCRIBE
  • 解释:用于查看表的结构,包括列名、数据类型、是否允许 NULL 值、默认值等信息。
  • 示例
DESCRIBE students;
ALTER TABLE
  • 解释:用于修改已存在表的结构,如添加列、删除列、修改列的数据类型等。
  • 示例
    • 添加列
ALTER TABLE students ADD COLUMN email VARCHAR(100);
  • 修改列的数据类型
ALTER TABLE students MODIFY COLUMN age TINYINT;
  • 删除列
ALTER TABLE students DROP COLUMN gender;
DROP TABLE
  • 解释:用于删除指定的表。表删除后,表中的所有数据和相关的索引、约束等都会被永久删除。
  • 示例
DROP TABLE students;

数据操作关键字

INSERT INTO
  • 解释:用于向表中插入新记录。可以指定要插入数据的列名和对应的值。
  • 示例
INSERT INTO students (student_name, age, class_id)
VALUES ('Alice', 18, 1);

如果要插入多行数据,可以使用以下语法:

INSERT INTO students (student_name, age, class_id)
VALUES ('Bob', 19, 2), ('Charlie', 20, 1);
SELECT
  • 解释:用于从表中查询数据。可以指定要查询的列、查询条件、排序方式等。
  • 示例
    • 查询所有列
SELECT * FROM students;
  • 查询指定列
SELECT student_name, age FROM students;
  • 带条件查询
SELECT * FROM students WHERE age > 18;
  • 排序查询
SELECT * FROM students ORDER BY age ASC;
  • 分页查询
SELECT * FROM students LIMIT 5 OFFSET 10;

此语句从第 11 条记录开始取 5 条记录。

UPDATE
  • 解释:用于修改表中已存在的记录。需要指定要更新的表、更新的列和新值,以及更新的条件。
  • 示例
UPDATE students
SET age = age + 1
WHERE class_id = 1;
DELETE
  • 解释:用于从表中删除记录。需要指定要删除记录的表和删除条件。如果不指定条件,将删除表中的所有记录。
  • 示例
DELETE FROM students WHERE student_name = 'Alice';

索引操作关键字

CREATE INDEX
  • 解释:用于在表的列上创建索引,以提高查询效率。索引可以加快数据的查找速度,但会增加插入、更新和删除操作的开销。
  • 示例
CREATE INDEX idx_student_name ON students (student_name);
DROP INDEX
  • 解释:用于删除已存在的索引。
  • 示例
DROP INDEX idx_student_name ON students;

事务处理关键字

START TRANSACTION
  • 解释:用于开始一个新的事务。事务是一组 SQL 语句的集合,这些语句要么全部成功执行,要么全部不执行。
  • 示例
START TRANSACTION;
COMMIT
  • 解释:用于提交事务。当事务中的所有 SQL 语句都成功执行后,使用 COMMIT 语句将事务中的更改永久保存到数据库中。
  • 示例
-- 开始事务
START TRANSACTION;
UPDATE accounts SET balance = balance - 100 WHERE account_id = 1;
UPDATE accounts SET balance = balance + 100 WHERE account_id = 2;
-- 提交事务
COMMIT;
ROLLBACK
  • 解释:用于回滚事务。当事务中的某个 SQL 语句执行失败或出现错误时,使用 ROLLBACK 语句将事务中的所有更改撤销,使数据库恢复到事务开始前的状态。
  • 示例
-- 开始事务
START TRANSACTION;
UPDATE accounts SET balance = balance - 100 WHERE account_id = 1;
-- 模拟错误
-- 发现余额不足等情况,回滚事务
ROLLBACK;

多表操作关键字

JOIN
  • 解释:用于将多个表中的数据根据指定的条件进行组合。常见的连接类型有内连接、左连接、右连接等。
  • 示例
    • 内连接
-- 假设存在 classes 表,包含 class_id 和 class_name 列
SELECT students.student_name, classes.class_name
FROM students
JOIN classes ON students.class_id = classes.class_id;
  • 左连接
SELECT students.student_name, classes.class_name
FROM students
LEFT JOIN classes ON students.class_id = classes.class_id;
  • 右连接
SELECT students.student_name, classes.class_name
FROM students
RIGHT JOIN classes ON students.class_id = classes.class_id;

以上就是 MySQL 数据库基础操作中常见关键字的详细解释和示例,通过掌握这些关键字和操作,你可以对 MySQL 数据库进行基本的管理和数据处理。


http://www.ppmy.cn/server/171434.html

相关文章

HTML——前端基础1

目录 前端概述 前端能做的事情​编辑 两步完成一个网页程序 前端工具的选择与安装 HTML HTML5介绍 HTML5的DOCTYPE声明 HTML基本骨架 文字标签 标题之标签 标签之段落、换行、水平线 标签之图片 标签之超文本链接 标签之文本 列表标签之有序列表 列表标签之无序…

推荐3个背景渐变色的wordpress主题

干净、清爽、背景渐变色的wordpress企业主题 ​ 服务类公司wordpress企业主题https://www.jianzhanpress.com/?p8255 红色大气的wordpress企业主题,适合服务行业的公司搭建企业官方网站使用。 ​ wordpress询盘型独立站主题https://www.jianzhanpress.com/?p8258…

vue+qrcode2批量生成二维码

1、安装qrcodejs2 npm install --save qrcodejs2 2、引用 import QRCode from "qrcodejs2"; 3、html代码 <div v-for"item in list" :key"item.id" class"itemDiv"><p class"qrCode-img"><span class"…

Ubuntu中dpkg命令和apt命令的关系与区别

在 Ubuntu 中&#xff0c;dpkg 和 apt 是软件包管理的核心工具&#xff0c;但二者的角色和功能有显著区别&#xff1a; ​一、功能定位 ​特性​​**dpkg**​​**apt**​​层级​底层工具&#xff08;直接操作 .deb 文件&#xff09;高层工具&#xff08;管理软件仓库和依赖关…

Mysql从入门到精通day1————数据库基本操作

本篇文章采用mysql的命令行工具进行讲解 输入密码即可进入&#xff0c;我这里的密码是root,环境是mysql9.1是目前的最新版本 (一)创建数据库操作 基本格式&#xff1a; CREATE {DATABASE/SCHEMA} [IF NOT EXISTS] 数据库名 【 【DEFAULT】CHARACTER SET[]字符集 | 【DEFA…

鸿蒙Next如何自定义标签页

前言 项目需求是展示标签&#xff0c;标签的个数不定&#xff0c;一行展示不行就自行换行。但是&#xff0c;使用鸿蒙原生的 Grid 后发现特别的难看。然后就想着自定义控件。找了官方文档&#xff0c;发现2个重要的实现方法&#xff0c;但是&#xff0c;官方的demo中讲的很少&…

C# 中 Array、ArrayList 和 List 的比较

C# 中 Array、ArrayList 和 List 的比较 在 C# 中&#xff0c;Array、ArrayList 和 List<T> 都用于存储和管理数据集合&#xff0c;但它们在类型安全性、性能、灵活性和使用场景上存在显著差异。以下是对这三种集合的详细比较&#xff1a; 1. 概述 特性ArrayArrayList…

【Python爬虫(95)】Python爬虫进阶:构建大型垂直领域爬虫系统

【Python爬虫】专栏简介:本专栏是 Python 爬虫领域的集大成之作,共 100 章节。从 Python 基础语法、爬虫入门知识讲起,深入探讨反爬虫、多线程、分布式等进阶技术。以大量实例为支撑,覆盖网页、图片、音频等各类数据爬取,还涉及数据处理与分析。无论是新手小白还是进阶开发…