表介绍
表相当于文件,表中的一条记录就相当于文件的一行内容,不同的是,表中的一条记录有对应的标题,称为表的字段
| id | name | sex | age |
|---|---|---|---|
| 1 | cy | male | 25 |
| 2 | ziy | female | 24 |
id,name,sex,age称为字段,其余的,一行内容称为一条记录
创建表
# 语法:
create table 表名(
字段名1 类型[(宽度) 约束条件],
字段名2 类型[(宽度) 约束条件],
字段名3 类型[(宽度) 约束条件]
);
# 注意:
1. 在同一张表中,字段名是不能相同
2. 宽度和约束条件可选
3. 字段名和类型是必须的
# 创建数据库db1
mysql> create database db1 charset utf8;
# 切换到db1数据库
mysql> use db1
Database changed
# 新建表t1
mysql> create table db1.t1(id int,name varchar(50),sex enum('male','female'),age int(3));
Query OK, 0 rows affected (0.03 sec)
# 查看db1库下所有表名
mysql> show tables;
+---------------+
| Tables_in_db1 |
+---------------+
| t1 |
+---------------+
# 查看t1的表结构
mysql> desc t1;
+-------+-----------------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+-----------------------+------+-----+---------+-------+
| id | int(11) | YES | | NULL | |
| name | varchar(50) | YES | | NULL | |
| sex | enum('male','female') | YES | | NULL | |
| age | int(3) | YES | | NULL | |
+-------+-----------------------+------+-----+---------+-------+
# 查看t1的表结构(表格格式内容过长会显示混乱)
mysql> show create table t1;
+-------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| Table | Create Table |
+-------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| t1 | CREATE TABLE `t1` (`id` int(11) DEFAULT NULL,`name` varchar(50) DEFAULT NULL,`sex` enum('male','female') DEFAULT NULL,`age` int(3) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8 |
+-------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
# 查看t1的表结构(\G)(关键部分)将结果以垂直格式显示,而不是传统的表格格式
*************************** 1. row ***************************Table: t1
Create Table: CREATE TABLE `t1` (`id` int(11) DEFAULT NULL,`name` varchar(50) DEFAULT NULL,`sex` enum('male','female') DEFAULT NULL,`age` int(3) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8
1 row in set (0.00 sec)
获取t1 表中的内容
# 获取id,name,sex,age列内容
mysql> select id,name,sex,age from t1;
Empty set (0.00 sec) # 没有数据
# 获取所有列内容
mysql> select * from t1;
Empty set (0.00 sec)
# 获取id,name列内容
mysql> select id,name from t1;
Empty set (0.00 sec)
往表中插入数据
mysql> insert into t1 values-> (1,'cy','male',25),-> (2,'ziy','female',24)-> ;mysql> select * from t1;
+------+------+--------+------+
| id | name | sex | age |
+------+------+--------+------+
| 1 | cy | male | 25 |
| 2 | ziy | female | 24 |
+------+------+--------+------+
2 rows in set (0.00 sec)# INSERT INTO t1(id):向表 t1 的 id 列插入数据
# VALUES (3), (4):插入两行数据,第一行 id=3,第二行 id=4
mysql> insert into t1(id) values-> (3),-> (4);
Query OK, 2 rows affected (0.01 sec)
Records: 2 Duplicates: 0 Warnings: 0mysql> select * from t1;
+------+------+--------+------+
| id | name | sex | age |
+------+------+--------+------+
| 1 | cy | male | 25 |
| 2 | ziy | female | 24 |
| 3 | NULL | NULL | NULL |
| 4 | NULL | NULL | NULL |
+------+------+--------+------+
4 rows in set (0.00 sec)
注意注意注意:表中的最后一个字段不要加逗号
查看表结构
mysql> describe t1; # 查看表结构,可简写为desc 表名
+-------+-----------------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+-----------------------+------+-----+---------+-------+
| id | int(11) | YES | | NULL | |
| name | varchar(50) | YES | | NULL | |
| sex | enum('male','female') | YES | | NULL | |
| age | int(3) | YES | | NULL | |
+-------+-----------------------+------+-----+---------+-------+
mysql> show create table t1; # 查看t1的表结构(表格格式内容过长会显示混乱)
+-------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| Table | Create Table |
+-------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| t1 | CREATE TABLE `t1` (`id` int(11) DEFAULT NULL,`name` varchar(50) DEFAULT NULL,`sex` enum('male','female') DEFAULT NULL,`age` int(3) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8 |
+-------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
# 查看t1的表结构(\G)(关键部分)将结果以垂直格式显示,而不是传统的表格格式
mysql> show create table t1\G;
*************************** 1. row ***************************Table: t1
Create Table: CREATE TABLE `t1` (`id` int(11) DEFAULT NULL,`name` varchar(50) DEFAULT NULL,`sex` enum('male','female') DEFAULT NULL,`age` int(3) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8
语法
1.修改表名
ALTER TABLE 表名 RENAME 新表名;
mysql> alter table t1 rename t2;
2.增加字段
ALTER TABLE 表名ADD 字段名 数据类型 [完整性约束条件…],ADD 字段名 数据类型 [完整性约束条件…];
ALTER TABLE 表名ADD 字段名 数据类型 [完整性约束条件…] FIRST;
ALTER TABLE 表名ADD 字段名 数据类型 [完整性约束条件…] AFTER 字段名;
3.删除字段
ALTER TABLE 表名 DROP 字段名;
4.修改字段
ALTER TABLE 表名 MODIFY 字段名 数据类型 [完整性约束条件…];
ALTER TABLE 表名 CHANGE 旧字段名 新字段名 旧数据类型 [完整性约束条件…];
ALTER TABLE 表名 CHANGE 旧字段名 新字段名 新数据类型 [完整性约束条件…];
复制表
# 复制表结构+记录 (key不会复制: 主键、外键和索引)
mysql> create table new_service select * from service;# 只复制表结构
mysql> select * from service where 1=2; # //条件为假,查不到任何记录
Empty set (0.00 sec)
mysql> create table new1_service select * from service where 1=2;
Query OK, 0 rows affected (0.00 sec)
Records: 0 Duplicates: 0 Warnings: 0
# 只复制表结构 like
mysql> create table t4 like employees;
删除表
drop table 表名;