MySQL对表的操作以及数据类型

文章目录

创建

sql 复制代码
create table table_name (
field1 datatype,
field2 datatype,
field3 datatype
) charset 字符集 collate 校验规则 engine 存储引擎;

其中field 表示列名,datatype表示列的类型,字符集、校验规则、存储引擎不指明则默认为配置文件里写好的。

sql 复制代码
create table if not exists user1(
name varchar(20) comment '用户名',
password char(32) comment '密码',
birthday date comment '生日'
)charset=utf8 collate utf8_general_ci engine MyIsam;

comment 后面代表着这一列数据的说明

删除表

sql 复制代码
drop table table_name;

查看

sql 复制代码
show tables;

可以查看当前数据库里的所有表

sql 复制代码
desc table_name;

查看指定一张表的详细属性

Field:字段名

Type:字段类型

Null:是否可以为空

Key:索引类型

Default:默认值

Extra:扩充

修改

重命名表

sql 复制代码
alter table table_name rename to new_name;

新增列

sql 复制代码
alter table table_name add 字段名 字段类型 after 字段名

after 字段名 代表着在指定的列后面新增

修改列的属性

sql 复制代码
alter table table_name modify 字段名 字段属性

修改的本质是将新的属性直接覆盖旧的属性

删除列

sql 复制代码
alter table table_name drop 字段名;

修改列名

sql 复制代码
alter table table_name change 旧列名 新列名 列的属性;

注意:修改列名不仅要把新的列名输入,列的属性也一定要带上

插入数据

sql 复制代码
insert into table_name values(Field1, Field2...);

values后面带的是需要插入的数据,并且以逗号为分割按列插入

数据类型

分类 数据类型 说明
bit 位类型,显示时按照ASCLL码对应的值显示
tinyint --- [unsingd] 带符号范围:-128127,不带符号:0255,默认有符号
bool 0和1表示真假
smallint --- [unsingd] 带符号范围:-215~215-1,不带符号:0~2^16-1,默认有符号
int --- [unsingd] 带符号范围:-231~231-1,不带符号:0~2^32-1,默认有符号
bigint --- [unsingd] 带符号范围:-263~263-1,不带符号:0~2^64-1,默认有符号
float(M, D) --- [unsingd] M指定显示长度,D指定小数位数,占用4字节
double(M, D) --- [unsingd] 比float精度更大的小数,占用8字节
decimal(M, D) --- [unsingd] M指定显示长度,D指定小数位数
char(size) 固定长度字符串,最大255
varchar(size) 可变长度字符串,最大65535
blob 二进制数据
text 大文本,不支持全文索引,不支持默认值
date/datetime/timestamp 日期类(yyyy-mm-dd)/(yyyy-mm-dd hh:mm:ss)/timestamp表示时间戳
enum 枚举类型
set 可以有0或者多个值,其值来自表创建是规定的列值

enum和set

enum属性定义值必须要在创建表时定义enum里的字段中,例如上面的 男和女 ,因此如果想插入数据enum的值必须在男和女中。其中不仅可以直接定义为男和女,也可以根据下标。如上定义的表中,顺序是 男,女。所以对应男的下标为1,女的下标为2,注意下标是从1开始的。

插入数据的set同样也必须在定义的set集合中,但是set并没有下标,而是对应比特位。例如上面定义的 篮球,羽毛球,游泳。则当设置为1时,也就是001,所以对应的就是篮球,为2时,010对应的就是羽毛球。如果为3,011,则代表着篮球和羽毛球两个,set是一个集合可以设置多个

enum和set的查找

enum直接根据属性即可查询,也可以根据下标

set的循环是一个严谨匹配的,可能会有包含了两个set属性的数据,但是如果只是指明的去查询并不会查到。

因此想要查询set中包含了某个属性就要使用 find_in_set 这个函数

相关推荐
倔强的石头_15 小时前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库
jiayou642 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
于眠牧北2 天前
MySQL的锁类型,表锁,行锁,MVCC中所使用的临键锁
mysql
李广坤3 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
Turnip12024 天前
深度解析:为什么简单的数据库"写操作"会在 MySQL 中卡住?
后端·mysql
爱可生开源社区4 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1774 天前
《从零搭建NestJS项目》
数据库·typescript
加号35 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏5 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
李慕婉学姐5 天前
Springboot智慧社区系统设计与开发6n99s526(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端