【MySQL】表的操作

目录

创建表

查看表

修改表

删除表


创建表

CREATE TABLE table_name (
field1 datatype,
field2 datatype,
field3 datatype

) character set 字符集 collate 校验规则 engine 存储引擎;

说明:

  • field 表示列名
  • datatype 表示列的类型
  • character set 字符集,如果没有指定字符集,则以所在数据库的字符集为准
  • collate 校验规则,如果没有指定校验规则,则以所在数据库的校验规则为准

我们当前在user_db这个数据库中,创建表之前里面只有一个文件
现在,我们在这个数据库中创建一个表

comment是该列的文字说明。最后一行的字符集和校验集可不写,默认继承与数据库

此时会发现这个数据库对应的文件目录里面多了3个文件

再来建一个表

会发现表user1有3个文件,表user2有2个文件,因为存储引擎不同。

建表后面的存储引擎也可不加,配置文件中默认的是InnoDB

查看表

查看当前数据库中有那些表

show tables;

具体查看某一张表的信息

desc 表名

查看指定表的创建语句

show create table 表名;

可在后面加\G,格式化显示,方便查看
此时我们查出来的创建语句与我们创建表时写的语句不太一样,因为mysqld会进行优化

MySQL上会记录用户的所有操作

修改表

在项目实际开发中,经常修改某个表的结构,比如字段名字,字段大小,字段类型,表的字符集类型,表的存储引擎等等。我们还有需求,添加字段,删除字段等等。这时我们就需要修改表。

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

修改表的名称

这里的to是可以省略的

向user表中插入一些数据

正常要insert into user (字段名称) values ... 表示给某一个字段插入,可省略括号中的内容,表示给全部字段插入

在users表添加一个字段,用于保存图片路径

after birthday表示在birthday这一列后面加上新的一列

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

修改name列,将其长度改成60

修改之前:

修改之后:

会发现,name这一列原本是有comment的,修改时若没加comment就没了。所以,是将新的属性直接覆盖的。

删除password列

将name列修改为xingming

删除表

DROP [TEMPORARY] TABLE [IF EXISTS] tbl_name [, tbl_name] ...

相关推荐
念九_ysl20 分钟前
Java 使用 OpenHTMLToPDF + Batik 将含 SVG 遮罩的 HTML 转为 PDF 的完整实践
java·开发语言·pdf
yaoxin52112329 分钟前
124. Java 泛型 - 有界类型参数
java·开发语言
liulilittle1 小时前
深度剖析:OPENPPP2 libtcpip 实现原理与架构设计
开发语言·网络·c++·tcp/ip·智能路由器·tcp·通信
88号技师1 小时前
2025年6月一区-田忌赛马优化算法Tianji’s horse racing optimization-附Matlab免费代码
开发语言·算法·matlab·优化算法
勤奋的知更鸟1 小时前
Java 编程之模板方法模式
java·开发语言·模板方法模式
十年编程老舅2 小时前
跨越十年的C++演进:C++20新特性全解析
c++·c++11·c++20·c++14·c++23·c++17·c++新特性
骑着王八撵玉兔2 小时前
【性能优化与架构调优(二)】高性能数据库设计与优化
数据库·性能优化·架构
Edingbrugh.南空2 小时前
Flink MySQL CDC 环境配置与验证
mysql·adb·flink
上单带刀不带妹2 小时前
手写 Vue 中虚拟 DOM 到真实 DOM 的完整过程
开发语言·前端·javascript·vue.js·前端框架
BD_Marathon3 小时前
Ubuntu:Mysql服务器
服务器·mysql·ubuntu