[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;

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

相关推荐
李白客15 小时前
KES新版MySQL兼容能力再升级意味着什么?
mysql·国产数据库
ClouGence17 小时前
Oracle 数据同步为什么会出现数据不一致?长事务是常被忽略的原因
数据库·后端·oracle
飞将19 小时前
从零实现数据库(2)——HashIndex + IndexManager
数据库
Nturmoils2 天前
订单列表慢查询,先看 WHERE、ORDER BY 和 LIMIT
数据库
渣波2 天前
拒绝 SQL 焦虑!手把手带你用 NestJS + Prisma + DTO 写出“防弹”级后端代码
javascript·数据库·后端
Jim6003 天前
【吃透 MySQL InnoDB连载】第 1 章・解密线上数据库高频故障
mysql
GreatSQL3 天前
gt-checksum v4.0.0 新功能解读系列文章(4):SSL 加密连接——数据校验传输安全再升级
mysql
倔强的石头_3 天前
KingbaseES 新版MySQL 兼容版体验:旧版迁移 + 功能实测
数据库
LinXunFeng3 天前
Obsidian - 使用 Share Note 分享笔记并自部署
前端·笔记·github