MySQL从建库到删库跑路 -- 4.表的操作

4 表操作

4.1 查找一个库中所有的表

  • 这个命令可以用于查找一个库中所有的表
SQL 复制代码
show tables from db_name;
sql 复制代码
mysql> show tables from hello;
+-----------------+
| Tables_in_hello |
+-----------------+
| hero            |
| test_bin        |
| test_ci         |
+-----------------+
3 rows in set (0.00 sec)

4.2 创建表

SQL 复制代码
create table table_name (
	field1 datatype,
	field2 datatype,
	field3 datatype
) [character set charset_name] [collate collation_name] [engine engine_name];
  • 这里我们可以指定存储引擎

4.3 查看表结构

SQL 复制代码
desc table_name;
字段 解释
Field 字段名
Type 类型
Null 是否允许为空
Key 索引类型
Default 默认值
Extra 扩展
  • 关于扩展

  • 扩展可以让一些字段拥有一些其他特性,比方说自动增长啥的

  • 关于索引

  • 首先,一个表在没有索引的情况下,本质上就会变成一个类似于deque的东西(一个缝合怪结构),以至于每次查找数据都需要从头遍历到尾,时间复杂度是O(N)

  • 于是我们可以给一个列创建索引,本质上是一个B+树,那么当查找这个列的元素时,就可以在B+树查找,效率为O(logN),本质上就是空间换时间

  • 值得一提的是,因为是deque,所以插入效率其实是挺高的,几乎就是O(1),但是如果有索引了,那么插入效率就会降到O(logN)

  • 另外,我觉得可以聊聊"写放大"问题

4.4 写放大问题(扩展)

  • 现在你有一个表cards,你想修改一个行中的id,修改大小也就几字节而已,那么在做这个操作时,到底动了多少磁盘多大的空间?

  • 你知道的,操作系统做读写时,即便不在MySQL中,也会按照页大小进行读写,换句话说,我们也就想修改几个字节而已,结果操作系统会读4KB到内存,这就是写放大问题

  • 另外,innodb这个存储引擎,他认为操作系统一个页为4KB太小了,所以innodb会按照16KB读到内存,这就加剧了写放大问题

  • 所以老实说,写放大问题我们没法避免,只能说尽可能减少这个问题发生的频率

  • 如果有索引,写放大问题一定会被放大,因为不仅基础的deque会有写放大,同时查找B+树也会有写放大问题

  • 不过老实说,如果在数据量没到达一定程度前,这点写放大其实问题都不大

  • 所以说,其实有索引的情况下,一定程度上会使得写效率降低一个数量级

4.5 修改表

  • 这几个命令用于增加,删除,修改一个表中的列
SQL 复制代码
alter table tablename add (column datatype [default expr][,column datatype]...);

alter table tablename modify (column datatype [default expr][,column datatype]...);

alter table tablename drop (column);
  • 你可以一次性新增或者修改多个列(如果你只对一个列做操作,记得把括号删了,括号是"多列模式")
  • 删除需谨慎!

  • 这个命令可以用于修改一个表的名字

SQL 复制代码
alter table table_name rename [to] other_name
  • to和不加to没有任何区别

4.6 删除表

SQL 复制代码
DROP [TEMPORARY] TABLE [IF EXISTS] tbl_name [, tbl_name] ...
  • [TEMPORARY]用于删除一个临时表
  • 关于临时表,MySQL允许用户创建一个临时的表,可以用于临时拆分一个超复杂的表,也可以用于用户测试一些指令什么的
  • 允许用户创建一个和正式表同名的临时表,临时表无法被其他用户看见,临时表会在用户退出MySQL时自动被释放
  • 如果加了这个关键字,即便存在一个同名的正式表,MySQL也不会尝试去删除正式表,换句话说,这是保护正式表的一种措施,保证只删除临时表
相关推荐
渐儿1 小时前
I/O 多路复用与 Reactor 模式:高性能服务的根基
后端
空中海2 小时前
Spring Boot 专家级面试题库
spring boot·后端·面试
fliter2 小时前
Cloudflare: Agent 现在可以自己注册账号、购买域名、部署上线了
后端
qq_283720052 小时前
Python3 模块精讲:pymysql(第三方)- 连接 MySQL
mysql·adb·pymysql
李日灐2 小时前
< 6 > Linux 自动化构建工具:makefile 详解 + 进度条实战小项目
linux·运维·服务器·后端·自动化·进度条·makefile
蝎子莱莱爱打怪2 小时前
小孩儿才做选择!Hermes 和OpenClaw 我都要!
人工智能·后端·github
直奔標竿2 小时前
SpringAI + RAG + MCP + Agent 零基础全栈实战(完结篇)| 27课完整汇总,Java开发者AI转型必看
java·开发语言·人工智能·spring boot·后端·spring
czlczl200209253 小时前
MySQL 性能优化:前缀索引(Prefix Index)深度解析
数据库·mysql·性能优化
枫叶林FYL3 小时前
项目八 云资源成本优化与治理平台
后端·python·自然语言处理·flask