从 SQL 语句到数据库操作

news/2025/2/10 23:19:54/
1. SQL 语句分类
  • 数据定义语言 DDL : 用于定义或修改数据库中的结构,如:创建、修改、删除数据库对象。createdrop alter

  • 数据操作语言 DML : 用于添加、删除、更新数据库中的数据。selectinsert alterdrop

  • 数据控制语言 DCL : 用于控制访问权限和管理数据库的安全性。grantrevokecommit

2. 存储引擎

存储引擎是数据库管理系统中的关键组件,它决定了数据如何被存储、组织以及检索

在 MySQL 中创建一个新的数据库时,会在文件系统上为该数据库创建一个对应的目录。

这个数据库通常包含了与该数据库相关的、所有表的数据文件、索引文件、以及其它文件。

不同的存储引擎可能会以不同的方式组织这些文件。

  • InnoDB : 默认存储引擎,支持事务处理、行级锁定和外键约束。InnoDB 设计用于最大化数据完整性和高并发环境下的性能。

适用于需要频繁写入操作,和事务支持的应用场景。

  • MyISAM : 不支持事务和行级锁定,但提供高速的查询性能和简单的维护管理。MyISAM 使用表级锁定,在执行写操作时,整个表会被锁定。

适合读密集型应用,但在高并发写场景时可能会遇到性能瓶颈。

3. 字符集和校验规则
3.1 数据库默认的字符集和校验规则

查看系统默认字符集:

show variables like 'character_set_database';

查看系统默认校验规则:

show variables like 'collation_database';

  • utf8mb4 : 字符集名称,表示支持完整的 Unicode 字符集,包括 4 字节的 UTF-8 编码字符。
  • utf8mb4_0900_ai_ci : 一种基于 Unicode 9.0.0 标准、忽略重音和大小写的校验规则,适用于 utf8mb4 字符集。
3.2 数据库支持的字符集和校验规则

查看数据库支持的字符集和字符集校验规则:

show charset;    # 查看数据库支持的字符集
show collation;  # 查看数据库支持的字符集校验规则
3.3 校验规则对数据库的影响
  • 不区分大小写

    create database temp2 charset=utf8mb4; # 使用默认字符串校验规则,不区分大小写
    use temp2;
    create table person (name varchar(20));

    insert into person values(‘a’);
    insert into person values(‘b’);
    insert into person values(‘c’);
    insert into person values(‘A’);
    insert into person values(‘B’);
    insert into person values(‘C’);

在这里插入图片描述

  • 区分大小写

    create database temp3 charset=utf8mb4 collate=utf8mb4_bin; # utf8mb4_bin 区分大小写
    use temp3;
    create table person (name varchar(20));

    insert into person values(‘a’);
    insert into person values(‘b’);
    insert into person values(‘c’);
    insert into person values(‘A’);
    insert into person values(‘B’);
    insert into person values(‘C’);

在这里插入图片描述

4. 修改、备份和恢复数据库
4.1 修改数据库
show create database temp2; # 查看数据库`temp2`是如何创建的

alter database temp2 charset=gbk; # 修改数据库`temp2`字符集为 gbk
show create database temp2;

4.2 备份数据库
mysqldump -P3306 -uroot -p -Btemp2 > /home/ZhengTongren/MySQL/temp2.bak
  • mysqldump 是一个命令行工具,而不是 SQL 语句,不能在 MySQL 客户端中直接运行。
  • mysqldump 需要指定一个具体的文件路径来保存文件;如果想备份保存到 /home/ZhengTongren/MySQL/ 路径下,需要确保该目录存在,并提供一个具体的文件名。

4.3 恢复数据库

登入 MySQL 客户端。

source /home/ZhengTongren/MySQL/temp2.bak;
5. 修改表
desc person; # 查看表`person`的结构信息# 插入两条数据
insert into person values (1, '张三');
insert into person values (2, '李四');

5.1 在 person 表中添加一个字段,保存 ‘年龄’
alter table person add age int comment '年龄' after name; # 在 name 后加入 age 列
select * from person;

插入新字段后,对原来表中的数据没有影响。

update person set age = 18 where name='张三';
update person set age = 21 where name='李四';

5.2 修改 name 字段长度,修改表名
# 修改 name 字段长度为 30
alter table person modify name varchar(30);
desc person;
# 修改表名
alter table person rename employee;
select * from employee;

5.3 删除 id 列

删除表中的一个字段时,该字段及其对应的所有数据都将被永久删除。

alter table employee drop id; # 前面修改过表名
select * from employee;


http://www.ppmy.cn/news/1570990.html

相关文章

MySQL 8.0.41 终端修改root密码

1.在 MySQL 命令行中,运行以下命令修改密码 ALTER USER rootlocalhost IDENTIFIED BY new_password; 其中,new_password替换为你想要设置的新密码 2.退出 MySQL终端,重新打开,使用新密码进入,修改成功

论文浅尝 | CogMG:大语言模型与知识图谱的协同增强(ACL2024)

笔记整理:杜超超,天津大学硕士,研究方向为自然语言处理、大语言模型 论文链接:https://aclanthology.org/2024.acl-demos.35.pdf 发表会议:ACL 2024 1. 动机 大语言模型(LLMs)在问答任务中已经被…

node.js使用mysql2对接数据库

一、引言 在现代Web开发中,Node.js作为一种高效、轻量级的JavaScript运行时环境,已经广泛应用于后端服务的开发中。而MySQL,作为一个广泛使用的关系型数据库管理系统(RDBMS),提供了强大的数据存储和查询功能…

[免费]微信小程序智能商城系统(uniapp+Springboot后端+vue管理端)【论文+源码+SQL脚本】

大家好,我是java1234_小锋老师,看到一个不错的微信小程序智能商城系统(uniappSpringboot后端vue管理端),分享下哈。 项目视频演示 【免费】微信小程序智能商城系统(uniappSpringboot后端vue管理端) Java毕业设计_哔哩哔哩_bilibili 项目介绍…

Python基础语法精要

文章目录 一、Python的起源二、Python的用途三、Python的优缺点优点缺点 四、基础语法(1)常量和表达式(2)变量变量的语法(i)定义变量(ii)变量命名的规则 (3)变…

网络安全—DDoS攻防

背景简述:DDoS攻击分为很多类型,有消耗网络带宽的流量攻击,有消耗服务器资源的应用层攻击等。影响巨大,且让无论大公司还是小公司都肃然“起敬”的当属:流量攻击。在流量越来越廉价的今天,攻击流量小则几百…

子集(力扣78)

这道题与之前做过的回溯问题最大的区别就是,我们在每一层递归都可以得到一个结果,也就是题目中所说的子集,而之前的题是在终止条件才将结果存入二维数组。需要注意的是,每一层递归中将结果存入二维数组的代码段需要放在终止条件之…

【使用小技巧】git rebase命令详解

Git Rebase命令介绍:场景与实例详解 在Git版本控制系统中,git rebase是一个强大且实用的命令,它用于重新整理提交历史,使提交记录更加线性和清晰。本文将通过具体场景和实际例子,详细介绍git rebase命令的使用方法和效…