壮心未与年俱老,死去犹能作鬼雄。这篇文章主要讲述MySQL数据库:数据表操作相关的知识,希望能为你提供帮助。
数据表操作
创建数据表1、基本语法
create table 表名 (
字段名 字段类型 [字段属性],
字段名 字段类型 [字段属性],
...
) [表选项];
需要注意:表需要放在对应的数据库下面
2、创建方式一
-- 先选择数据库
use mydatabase;
-- 创建数据表
create table user(
name varchar(10)
);
3、创建方式二
-- 直接将数据表挂到数据库下
create table mydatabase.user(
name varchar(10)
);
4、表选项
- Engine 存储引擎
- Charset 字符集
- Collate 校对集
create table user(
name varchar(10)
) charset utf8;
5、复制已有表结构
create table 表名 like 表名;
-- eg 从test数据库复制表
create table user like test.user;
显示数据表
-- 显示所有表
mysql>
show tables;
+----------------------+
| Tables_in_mydatabase |
+----------------------+
| t_author|
| user|
+----------------------+-- 显示匹配表
mysql>
show tables like %author;
+--------------------------------+
| Tables_in_mydatabase (%author) |
+--------------------------------+
| t_author|
+--------------------------------+
显示表结构基本语法
desc 表名(常用);
describe 表名;
show columns from 表名;
示例
mysql>
desc user;
+-------+-------------+------+-----+---------+-------+
| Field | Type| Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| name| varchar(10) | YES|| NULL||
+-------+-------------+------+-----+---------+-------+
1 row in set (0.00 sec)mysql>
describe user;
+-------+-------------+------+-----+---------+-------+
| Field | Type| Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| name| varchar(10) | YES|| NULL||
+-------+-------------+------+-----+---------+-------+
1 row in set (0.01 sec)mysql>
show columns from user;
+-------+-------------+------+-----+---------+-------+
| Field | Type| Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| name| varchar(10) | YES|| NULL||
+-------+-------------+------+-----+---------+-------+
1 row in set (0.01 sec)
字段含义
Field字段名
Type字段类型
Null是否允许为空
Key索引
Default默认值
Extra额外的属性
显示表创建语句基本语法
show create table 表名;
示例
mysql>
show create table user;
+-------+----------------+
| Table | Create Table|
+-------+----------------+
| user| CREATE TABLE `user` (
`name` varchar(10) COLLATE utf8mb4_general_ci DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci |
+-------+----------------+
1 row in set (0.00 sec)
语句结束符
;
\\g
效果一样,字段在上,数据在下\\G
字段在左,数据在右
mysql>
show create table user\\G
*************************** 1. row ***************************
Table: user
Create Table: CREATE TABLE `user` (
`name` varchar(10) COLLATE utf8mb4_general_ci DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci
1 row in set (0.00 sec)
设置表属性
- engine
- charset
- collate
-- 基本语法
alter table 表名 表选项 [=] 值;
-- eg 修改表的字符集
alter table user charset gbk;
如果数据表已经有数据,不要轻易修改表属性
修改表结构1、修改表名
--基本语法
rename table 旧表名 to 新表名;
-- eg:
rename table user to tb_user;
2、新增字段
-- 基本语法
alter table 表名 add [column] 字段名 字段类型 [字段属性] [位置first/after 字段名];
mysql>
desc user;
+-------+-------------+------+-----+---------+-------+
| Field | Type| Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| name| varchar(10) | YES|| NULL||
+-------+-------------+------+-----+---------+-------+-- 给学生表新增age字段,默认加到表的最后
mysql>
alter table tb_user add age int;
mysql>
desc tb_user;
+-------+-------------+------+-----+---------+-------+
| Field | Type| Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| name| varchar(10) | YES|| NULL||
| age| int(11)| YES|| NULL||
+-------+-------------+------+-----+---------+-------+-- 在最前面增加一个id字段
mysql>
alter table tb_user add id int first;
mysql>
desc tb_user;
+-------+-------------+------+-----+---------+-------+
| Field | Type| Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| id| int(11)| YES|| NULL||
| name| varchar(10) | YES|| NULL||
| age| int(11)| YES|| NULL||
+-------+-------------+------+-----+---------+-------+
字段位置
first放在最前名
alter 字段名放在某个字段后面
3、修改字段名
-- 基本语法
alter table 表名 change 旧字段名 新字段名 字段类型 [字段属性] [新位置]-- 将age字段修改为old
mysql>
alter table tb_user change age old int;
mysql>
desc tb_user;
+-------+-------------+------+-----+---------+-------+
| Field | Type| Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| id| int(11)| YES|| NULL||
| name| varchar(10) | YES|| NULL||
| old| int(11)| YES|| NULL||
+-------+-------------+------+-----+---------+-------+
4、修改字段属性
-- 基本语法
alter table 表名 modify 字段名 新字段类型 [新字段属性] [新位置]-- eg 将name的长度由10修改为20
mysql>
alter table tb_user modify name varchar(20);
mysql>
desc tb_user;
+-------+-------------+------+-----+---------+-------+
| Field | Type| Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| id| int(11)| YES|| NULL||
| name| varchar(20) | YES|| NULL||
| old| int(11)| YES|| NULL||
+-------+-------------+------+-----+---------+-------+
【MySQL数据库(数据表操作)】5、删除字段
-- 基本语法
alter table 表名 drop 字段名-- eg 删除old字段
alter table tb_user drop old;
删除表结构
-- 基本语法, 可以同时删除多个表
drop table 表名 [, 表名...];
-- eg: 删除 tb_user表
mysql>
drop table tb_user;
mysql>
show tables;
+----------------------+
| Tables_in_mydatabase |
+----------------------+
| t_author|
+----------------------+
推荐阅读
- [ 数据结构-C语言 ] 算法的时间复杂度
- Linux 内核 内存管理分区伙伴分配器 ③ ( 备用内存区域列表 | ZONELIST_FALLBACK 枚举 | zoneref 结构体 | 备用内存区域借用物理页规则 )
- Linux 内核 内存管理物理分配页 ② ( __alloc_pages_nodemask 函数参数分析 | __alloc_pages_nodemask 函数分配物理页流程 )
- PE工具中的WinNTSetup(又称 win安装器)
- 利用QEMU+GDB搭建Linux内核调试环境
- 安装npm 并启动vue 项目
- win7 安装composer 报错
- SAP WM 初阶之不常用事务代码LB01 - Create TR Document
- SAP WM初阶之事务代码LS22 - Change Quant