[24年单独笔记] MySQL 常用的 DML 命令

Work with MySQL < Frame_TABLE

续借 Frame 上文,接下来我们创建一份包含以下内容的 base.sql 文件进行教学。

sql 复制代码
# MySQL 应用命令文件

# 如果数据库存在则执行此命令
DROP DATABASE IF EXISTS maic;

CREATE DATABASE maic
CHARACTER SET = utf8mb4;

USE maic;

CREATE TABLE maic_user(
    id INT(11) AUTO_INCREMENT PRIMARY KEY,
    uid INT(12) NOT NULL UNIQUE,
    email VARCHAR(30) NOT NULL,
    pwd VARCHAR(20) NOT NULL,
    nick VARCHAR(10)
);

对MySQL进行导入初始化:

shell 复制代码
mysql -uroot -p123456 < ./base.sql

附加参数讲解:

  1. PRIMARY KEY(主键)
  2. NOT NULL (不允许内容为空)
  3. UNIQUE (内容的值只能出现一次)
  4. AUTO_INCREMENT (数值自动递增,仅限INT)

ℹ️ 值得注意的是,它顶多只能满足1,2级范式要求,如果你希望满足更高范式请参考下面内容!

以下二者均可以在 CREATE TABLE 中使用

设置联合主键(多主键)

sql 复制代码
CREATE TABLE xxx
(
    ...
    PRIMARY KEY(id,uid)
);

设置外键(从表)

sql 复制代码
CREATE TABLE xxx
(
    ...
    CONSTRAINT 约束名称,不能重复 FOREIGN KEY(外键列名,在当前表内) REFERENCES 关联表名(关联列名)   
);


# 建议使用 fk_ 进行开头
ALTER TABLE xxx
CONSTRAINT fk_l_t
FOREIGN KEY(外键列名) REFERENCES 关联表名(关联列名);

此外,还有一种方式进行附加

sql 复制代码
ALTER TABLE xx
ADD FOREIGN KEY(本表列名) REFERENCES yy(yy表列名);

这种方式不直接使用外键约束,而是通过在数据库层面上创建索引来模拟外键关联的效果。
REFERENCES 指向的是 主表

启用外键需要满足以下条件!

  1. InnoDB引擎需要启用!
  2. 类型长度相同
  3. 并且关联列必须是唯一索引(UNIQUE)或主键(PRIMARY KEY)

无论在何时何地,你必须遵守 SQL的编写规范性要求 ,例如属于 MySQL的官方命令 内容,均采用 大写。自定义的数据内容等采用小写,防止命令混淆!

创建一个用户,访问MySQL服务,避免权限管控问题。

如果使用的是 Linux类 系统,文件位于: /etc/my.cnf

sql 复制代码
# 创建一个asker用户,密码:123456
CREATE USER 'asker'@'localhost' IDENTIFIED BY '123456';

# 授予asker用户访问 maic数据库下所有表 的权限
GRANT ALL PRIVILEGES ON maic.* TO 'asker'@'localhost';

# 刷新权限配置
FLUSH PRIVILEGES;

# 检查权限是否正确
SHOW GRANTS FOR 'asker'@'localhost';

使用数据库管理数据有严禁更改数据结构的忌讳!在添加记录前,必须提前分配好字段!

以ASKER的身份登录MySQL:

shell 复制代码
mysql -uasker -p123456

⚠️需要注意的是,创建用户的权限无法访问 MySQL 和 SYS 这两个数据库

sql 复制代码
SHOW DATABASES;

USE maic;

# 修改表名称
ALTER TABLE maic_user
RENAME AS profile;

RENAME TABLE profile TO info;

此时,表 maic_user 名称则被修改为了 info,我们克隆一份表结构 (并非表数据)供日后还原:

sql 复制代码
CREATE TABLE profile
LIKE info;

如果希望完全复制一份表(包括数据):

sql 复制代码
CREATE TABLE profile
AS SELECT * FROM info;

至此,你应当学会了表结构的基本维护与运营。我们不推荐你一次性学完,请提取出符合你学习体系的相关知识!

相关推荐
lwewan4 小时前
CPU 调度
笔记·考研
SPC的存折4 小时前
MySQL 8.0 分库分表
linux·运维·服务器·数据库·mysql
John.Lewis4 小时前
C++进阶(6)C++11(2)
开发语言·c++·笔记
蓦然乍醒4 小时前
使用 DBeaver 还原 PostgreSQL 备份文件 (.bak) 技术文档
数据库·postgresql
XDHCOM4 小时前
Redis节点故障自动恢复机制详解,如何快速抢救故障节点,确保数据不丢失?
java·数据库·redis
QCzblack4 小时前
BugKu BUUCTF ——Reverse
java·前端·数据库
cyber_两只龙宝4 小时前
【Oracle】Oracle之DQL中WHERE限制条件查询
linux·运维·数据库·云原生·oracle
luis的妙妙屋4 小时前
主流数据库数据类型对比分析
数据库
XDHCOM4 小时前
ORA-00054资源忙故障修复,远程处理Oracle报错解决方案,数据库锁超时NOWAIT指定问题排查
数据库·oracle