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 这个函数

相关推荐
一 乐2 小时前
民宿|基于java的民宿推荐系统(源码+数据库+文档)
java·前端·数据库·vue.js·论文·源码
鹏码纵横2 小时前
已解决:java.lang.ClassNotFoundException: com.mysql.jdbc.Driver 异常的正确解决方法,亲测有效!!!
java·python·mysql
美林数据Tempodata3 小时前
大模型驱动数据分析革新:美林数据智能问数解决方案破局传统 BI 痛点
数据库·人工智能·数据分析·大模型·智能问数
野槐3 小时前
node.js连接mysql写接口(一)
数据库·mysql
Zzzone6834 小时前
PostgreSQL日常维护
数据库·postgresql
chxii4 小时前
1.13使用 Node.js 操作 SQLite
数据库·sqlite·node.js
冰刀画的圈4 小时前
修改Oracle编码
数据库·oracle
这个胖子不太裤4 小时前
Django(自用)
数据库·django·sqlite
麻辣清汤4 小时前
MySQL 索引类型及其必要性与优点
数据库·mysql
2501_915374355 小时前
Neo4j 图数据库安装教程(2024最新版)—— Windows / Linux / macOS 全平台指南
数据库·windows·neo4j