MySQL表的操作

目录

创建表

创建表案例

查看表结构

修改表

修改表名

修改列

删除表

创建表

语法:

说明:
field 表示列名
datatype 表示列的类型
character set 字符集,如果没有指定字符集,则以所在数据库的字符集为准

collate 校验规则,如果没有指定校验规则,则以所在数据库的校验规则为准

创建表案例

两个不同的存储引擎

CREATE TABLE test (

-> id INT,

-> name VARCHAR(20) COMMENT '用户名',

-> password CHAR(32) COMMENT '密码是32位的md5值',

-> birthday DATE COMMENT '生日'

-> ) CHARACTER SET utf8 ENGINE MyISAM;

CREATE TABLE test2 (

id INT,

name VARCHAR(20) COMMENT '用户名',

password CHAR(32) COMMENT '密码是32位的md5值',

birthday DATE COMMENT '生日'

) CHARACTER SET utf8 ENGINE InnoDB;

comment是描述信息的,大小写都行
说明:不同的存储引擎,创建表的文件不一样。

test表存储引擎是MyISAM ,在数据目中有三个不同的文件,分别是:test.frm test.MYD test.MYI

表结构 表数据 表索引

而test2表存储引擎是 InnoDB,他的数据和索引在一个文件里,所以有两个文件

查看表结构

desc 表名; 查看一个表的详细信息



show create table test;显示建表时的详细信息

建议使用 show create table test \G

\G是将不需要的信息过滤掉

修改表

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

修改表名

alter table x rename to xx;//注意to可以省略

修改列

alter table意思是要改表了

插入信息:

insert into test1 values(1,'张三','12345','1982-01-04');

insert into test1 values(2,'李四','54321','1983-01-04');
插入新字段列:

alter table test1 add image_path varchar(128) comment '这个是用户的头像路径' after birthday;

新建一列并且在birthday后面

插入新字段后对原来的数据没影响

修改字段列数据类型大小:

alter table test1 modify name varchar(60);


但是查看后发现:原本的comment描述信息不见了。说明是覆盖的改动
删除列:

alter table test1 drop password;删除password列


删除字段一定要小心,删除字段及其对应的列数据都没了
改列名称:

alter table test1 change name xingming varchar(60) DEFAULT NULL;

alter table test1 change xingming name varchar(60) ;

不只是改名字同时相应的信息也要改

单纯改名字不对,要带上字段类型。

DEFAULT NULL是由show create table test1 \G;得来的是数据库优化来得,带不带都行。

删除表

drop table test1;

总之不要轻易修改和删除因为关联很多东西 ,轻易修改会导致改动很多东西。

相关推荐
林姜泽樾36 分钟前
Linux入门第十二章,创建用户、用户组、主组附加组等相关知识详解
linux·运维·服务器·centos
执笔画情ora1 小时前
Postgresql数据库管理-pg_xact
数据库·postgresql·oracle
xiaokangzhe1 小时前
Linux系统安全
linux·运维·系统安全
feng一样的男子1 小时前
NFS 扩展属性 (xattr) 提示操作不支持解决方案
linux·go
南棱笑笑生1 小时前
20260310在瑞芯微原厂RK3576的Android14查看系统休眠时间
服务器·网络·数据库·rockchip
JuneXcy2 小时前
第4章 Mysql数据操纵语句--单表查询
mysql
XDHCOM2 小时前
ORA-32152报错咋整啊,数据库操作遇到null number问题远程帮忙修复
服务器·数据库·oracle
专利观察员2 小时前
输配电行业创新转型实践:南宁迪**力有限公司的专利策略调整、专利检索工具采用
数据库·科技·专利·专利申请
jgyzl2 小时前
2026.3.9 Redis内存回收内存淘汰
数据库·redis·缓存
Highcharts.js2 小时前
Highcharts React v4.2.1 正式发布:更自然的React开发体验,更清晰的数据处理
linux·运维·javascript·ubuntu·react.js·数据可视化·highcharts