目录
一、理论
1.克隆表与清空表
克隆表:将数据表的数据记录生成到新的表中。
(1)克隆表
① 先创建再导入
bash
create table 新表 like 旧表;
insert into 新表 select * from 旧表;
例如:
create table test1 like students; #通过 LIKE 方法,复制 info 表结构生成 test01 表
insert into test1 select * from students; #导入数据
② 创建的时候同时导入
bash
create table test2 (select * from students);
(2)清空表
清空表:删除表内的所有数据。
①delete删除(自增长)
DELETE清空表后,返回的结果内有删除的记录条目;DELETE工作时是一行一行的删除记录数据的;如果表中有自增长字段,使用DELETE FROM 删除所有记录后,再次新添加的记录会从原来最大的记录 ID 后面继续自增写入记录。
②truncate删除(重新记录)
TRUNCATE 清空表后,没有返回被删除的条目;TRUNCATE 工作时是将表结构按原样重新建立,因此在速度上 TRUNCATE 会比 DELETE 清空表快;使用 TRUNCATE TABLE 清空表内数据后,ID 会从 1 开始重新记录。
bash
truncate table 表名;
例如:
truncate table test1;
③创建临时表(退出数据库自动销毁)
临时表创建成功之后,使用SHOW TABLES命令是看不到创建的临时表的,临时表会在连接退出后被销毁。 如果在退出连接之前,也可以可执行增删改查等操作,比如使用 DROP TABLE 语句手动直接删除临时表。
bash
##添加临时表test3
create temporary table test3 (
id int(4) zerofill primary key auto_increment,
name varchar(10) not null,
cardid int(18) not null unique key,
hobby varchar(50));
show tables; ## 查看当前库中所有表
insert into test3 values(1,'zhangsan',123456789,'watch a film'); ##在临时表中添加数据
select * from test3; ##查看当前表中所有数据
quit ##退出数据库
mysql -u root -p ##重新登录后进行查看
select * from test3; ##查看之前创建的临时表中所有数据,发现已经被自动销毁
2.SQL高级语句
data:image/s3,"s3://crabby-images/a771f/a771fa1fd5d6b720db985141cd1d31b43109b9f7" alt=""
(1)select查询语句
①select:显示表格中的一个或者多个字段中所有的信息
bash
#格式:select 字段名 from 表名;
#示例1:显示数据表students的所有数据
select * from students;
#示例2:显示数据表students的名字与年龄字段
select name,age from students;
②distinct查询不重复记录
bash
#语法:select distinct 字段 from 表名﹔
#示例1:去除年龄字段中重复的
select distinct age from students;
#示例2:查找性别
select distinct gender from students;
③where根据条件查询
bash
#语法:select '字段' from 表名 where 条件
#示例:显示name和age 字段 并且要找到age小于20
select name,age from students where age < 20;
④and且、or或:根据多个条件查询
bash
#语法:select 字段名 from 表名 where 条件1 (and|or) 条件2 (and|or)条件3;
#示例:显示name和age 并且要找到age大于20小于30
select name,age from students where age >20 and age <30;
⑤in显示已知值的资料
bash
#语法:select 字段名 from 表名 where 字段 in ('值1','值2'....);
#示例1:显示学号为1,2,3,4的学生记录
select * from students where StuID in (1,2,3,4);
#示例2:显示班级为1和3的学生记录
select * from students where ClassID in (1,3);
⑥between:显示两个值范围内的资料
bash
#语法:select 字段名 from 表名 where 字段 between '值1' and '值2';
包括 and两边的值
#示例1:显示学生姓名在Ding Dian和Hua Rong中的学生记录
select * from students where name between 'ding dian' and 'Hua Rong';
#示例2:显示学生号码id在2-5 的信息
select * from students where stuid between 2 and 5;
#示例3:显示学生年龄在20-35之间的信息,不需要表中一定有该字段,只会将20到25 已有的都显示出来
select * from students where age between 20 and 25;
⑦ like+通配符:模糊查询
表1 like通配符
|------|----------------------------------------------------------------|
| 通配符 | 含义 |
| % | 表示零个,一个或者多个字符 |
| _ | 下划线表示单个字符 |
| A_Z | 所有以A开头 Z 结尾的字符串 'ABZ' 'ACZ' 'ACCCCZ'不在范围内 下划线只表示一个字符 AZ 包含a空格z |
| ABC% | 所有以ABC开头的字符串 ABCD ABCABC |
| %CBA | 所有以CBA结尾的字符串 WCBA CBACBA |
| %AN% | 所有包含AN的字符串 los angeles |
| _AN% | 所有 第二个字母为 A 第三个字母 为N 的字符串 |
bash
#语法:select 字段名 from 表名 where 字段 like 模式
bash
#示例1:查找名字以s开头的学生记录
select * from students where name like 's%';
#示例2:查找名字包含ong的学生记录
select * from students where name like '%ong%';
#示例3:查找名字第二个字母为u,第三个字母为a的学生记录
select * from students where name like '_ua%';
(8)order by按关键字排序
bash
#语法:
select 字段名 from 表名 where 条件 order by 字段 [asc,desc];
#############################################################
asc :正向排序
desc :反向排序
######################默认是正向排序##########################
bash
#示例1:按学生的年龄正向排序显示年龄和姓名字段
select age,name from students order by age;
#示例2:按学生的年龄反向排序显示年龄和姓名字段
select age,name from students order by age desc;
#示例3:显示name、age和classid字段的数据 并且只显示classid字段为3 的 并且以age字段排序
select age,name,classid from students where classid=3 order by age;
3.SQL函数
(1)数学函数
表2 数学函数
|----------|-------------|
| 函数 | 含义 |
| abs(x) | 返回x 的 绝对值 |
| rand() | 返回0到1的随机数 |
| mod(x,y) | 返回x除以y以后的余数 |
| abs(x) | 返回x 的 绝对值 |
| rand() | 返回0到1的随机数 |
| mod(x,y) | 返回x除以y以后的余数 |
| abs(x) | 返回x 的 绝对值 |
| rand() | 返回0到1的随机数 |
| mod(x,y) | 返回x除以y以后的余数 |
| abs(x) | 返回x 的 绝对值 |
| rand() | 返回0到1的随机数 |
| mod(x,y) | 返回x除以y以后的余数 |
bash
#示例1:返回-2的绝对值
select abs(-2);
#示例2:随机生成一个数
select rand (1);
#示例3:随机生成排序
select * from students order by rand();
#示例4:返回7除以2以后的余数
select mod(7,2);
#示例5:返回2的3次方
select power(2,3);
#示例6:返回离2.6最近的数
select round(2.6);
#返回离2.4最近的数
select round(2.4);
#示例7:保留2.335321的3位小数四舍五入后的值
select round(2.335321,2);
#示例8:返回数字 2.335321 截断为2位小数的值
select truncate(2.335321,2);
#示例9:返回大于或等于2.335321 的最小整数
select ceil(2.335321);
#示例10:返回小于或等于 2.335321 的最大整数
select floor(2.335321);
#示例11:返回集合中最大的值
select greatest(1,4,3,9,20);
#示例12:返回集合中最小的值
select least(1,4,3,9,20);
(2)聚合函数
表3 聚合函数
|---------|-------------------|
| 函数 | 含义 |
| avg() | 返回指定列的平均值 |
| count() | 返回指定列中非 NULL 值的个数 |
| min() | 返回指定列的最小值 |
| avg() | 返回指定列的平均值 |
| count() | 返回指定列中非 NULL 值的个数 |
| min() | 返回指定列的最小值 |
bash
#示例1:求表中年龄的平均值
select avg(age) from students;
#示例2:求表中年龄的总和
select sum(age) from students;
#示例3:求表中年龄的最大值
select max(age) from students;
#示例4:求表中年龄的最小值
select min(age) from students;
#示例5:求表中有多少班级字段非空记录
select count(classid) from students;
count(明确字段):不会忽略空记录
#示例6:求表中有多少条记录
select count(*) from students;
count(*)包含空字段,会忽略空记录
#示例7:看空格字段是否会被匹配
insert into students values(26,' ',28,'f',1,8);
(3)字符串函数
表4 字符串函数
|----------------|---------------------------------------------|
| 函数 | 描述 |
| trim() | 返回去除指定格式的值 |
| concat(x,y) | 将提供的参数 x 和 y 拼接成一个字符串 |
| substr(x,y) | 获取从字符串 x 中的第 y 个位置开始的字符串,跟substring()函数作用相同 |
| substr(x,y,z) | 获取从字符串 x 中的第 y 个位置开始长度为z 的字符串 |
| length(x) | 返回字符串 x 的长度 |
| replace(x,y,z) | 将字符串 z 替代字符串 x 中的字符串 y |
| upper(x) | 将字符串 x 的所有字母变成大写字母 |
| lower(x) | 将字符串 x 的所有字母变成小写字母 |
| left(x,y) | 返回字符串 x 的前 y 个字符 |
| right(x,y) | 返回字符串 x 的后 y 个字符 |
| repeat(x,y) | 将字符串 x 重复 y 次 |
| space(x) | 返回 x 个空格 |
| strcmp(x,y) | 比较 x 和 y,返回的值可以为-1,0,1 |
| reverse(x) | 将字符串 x 反转 |
(1) trim返回去除指定格式的值
bash
语法:select trim (位置 要移除的字符串 from 字符串)
其中位置的值可以是
leading(开始)
trailing(结尾)
both(起头及结尾)
#区分大小写
要移除的字符串:从字符串的起头、结尾或起头及结尾移除的字符串,缺省时为空格。
bash
#示例:从名字开头的开始,移除Sun Dasheng中的Sun显示
select trim(leading 'Sun' from 'Sun Dasheng');
(2) length返回字符串的长度
bash
#语法:select length(字段) from 表名;
#示例:计算出字段中记录的字符长度
select name,length(name) from students;
(3)replace替代
bash
#语法:select replace(字段,'原字符''替换字符') from 表名;
#示例:查看名字里包含ua的记录
select name from students where name like '%ua%';
#将ua替换成hh显示出来
select replace(name,'ua','hh') from students;
(4)concat将提供的参数拼接成一个字符串
bash
#语法:select concat(字段1,字段2)from 表名
#示例:将name,classid字段拼接成一个字符串
select concat(name,classid) from students;
(5) substr:根据要求截取长度查看
bash
#语法:select substr(字段,开始截取字符,截取的长度) where 字段='截取的字符串'
#示例1:截取第6个字符往后
select substr(name,6) from students where name='Yue Lingshan';
#示例2:截取第6个字符往后的两个字符
select substr(name,6,2) from students where name='Yue Lingshan';
4.SQL高级操作
(1)group by查询结果进行汇总分组
对group by 后面的字段的查询结果进行汇总分组,通常是结合聚合函数一起使用的;
group by 有一个原则,就是select 后面的所有列中,没有使用聚合函数的列必须出现在 group by 的后面。
bash
#语法:select 字段1,sum(字段2) from 表名 group by 字段1;
#示例1:求各个班的年龄总和
select classid,sum(age) from students group by classid;
#示例2:求各个班的平均年龄
select classid,avg(age) from students group by classid;
#示例3:根据年龄查看每个班的人数
select classid,count(age) from students group by classid;
(2)having过滤返回的记录集
having:用来过滤由group by语句返回的记录集,通常与group by语句联合使用;
having语句的存在弥补了where关键字不能与聚合函数联合使用的不足。如果被SELECT的只有函数栏,那就不需要GROUP BY子句;
要根据新表中的字段,来指定条件。
bash
#语法:
select 字段1,SUM("字段")from 表格名 group by 字段1 having(函数条件);
#示例:查看各个班的平均年龄在30以上的班级
select classid,avg(age) from students group by classid having avg(age) > 30;
(3)as别名
栏位別名 表格別名。
bash
#语法:
SELECT "表格別名"."栏位1" [AS] "栏位別名" FROM "表格名" [AS] "表格別名";
#示例:设置表名别名为f,基于班级号来统计各班年龄总和,sum(age)定义别名为total age
select f.classid,sum(age) 'total age' from students as f group by f.classid;
(4)连接查询
准备两个表,此处两个表分别为students和scores
① inner join(等值相连):只返回两个表中联结字段相等的行
bash
SELECT * FROM students A INNER JOIN scores B on A.stuid = B.stuid;
② left join(左联接):返回包括左表中的所有记录和右表中联结字段相等的记录
bash
select * from scores A left join students B on A.stuid = B.stuid;
③ right join(右联接):返回包括右表中的所有记录和左表中联结字段相等的记录
bash
select * from scores A right join students B on A.stuid = B.stuid;
(5)子查询
连接表格,在WHERE 子句或HAVING 子句中插入另一个SQL语句
bash
语法:SELECT "栏位1" FROM "表格1" WHERE "栏位2" [比较运算符]
#外查询
(SELECT "栏位1" FROM "表格1" WHERE "条件");
#示例:查询学生学号为1的得分总和
select sum(score) from scores where stuid in (select stuid from students where stuid=1);
5.MySQL中6种常见的约束
(1)约束
表5 常见约束
|----|------------------------------|
| 序号 | 约束类型 |
| 1 | 主键约束(primary key) |
| 2 | 外键约束(foreign key) |
| 3 | 非空约束(not null) |
| 4 | 唯一性约束(unique [key|index]) |
| 5 | 默认值约束(default) |
| 6 | 自增约束(auto_increment) |
(2)外键
外键的定义:如果同一个属性字段x在表一中是主键,而在表二中不是主键,
则字段x称为表二的外键。
表6 主键表和外键表
|-----|------------------------|---------------------------------------------------------------|
| 类别 | 描述 | 备注 |
| 主键表 | 以公共关键字作主键的表为主键表(父表、主表) | 与外键关联的主表的字段必须设置为主键。要求从表不能是临时表, 主表外键字段和从表的字段具备相同的数据类型、字符长度和约束。 |
| 外键表 | 以公共关键字作外键的表为外键表(从表、外表) | 与外键关联的主表的字段必须设置为主键。要求从表不能是临时表, 主表外键字段和从表的字段具备相同的数据类型、字符长度和约束。 |
二、实验
1.克隆表与清空表
(1)克隆版
①先创建再导入
data:image/s3,"s3://crabby-images/c0565/c0565a5ac37b527264e7a248627f2f7574d9b4b8" alt=""
②创建的时候同时导入
data:image/s3,"s3://crabby-images/67d76/67d7634dfb521d598407d99d45f504fe84c33aef" alt=""
(2)清空表
① delete删除(自增长)
data:image/s3,"s3://crabby-images/5f23b/5f23bd8db84680e5be813ddca45fad7145e76a35" alt=""
② truncate删除(重新记录)
data:image/s3,"s3://crabby-images/7feb7/7feb7bcfc8b04121a43645a5d5ee9ac4fcd30814" alt=""
③ 创建临时表(退出数据库自动销毁)
data:image/s3,"s3://crabby-images/e400d/e400d0793f22b379c747825b9ad4aa4dd2b1a6f7" alt=""
data:image/s3,"s3://crabby-images/5d3b0/5d3b0b3479010f6a4333797df884d694a8b2348b" alt=""
2.SQL高级语句
(1)select:显示表格中的一个或者多个字段中所有的信息
data:image/s3,"s3://crabby-images/f178b/f178ba7ab0ccea159ea2778892cf8bb72051181d" alt=""
显示所有
显示数据表students的名字与年龄字段
data:image/s3,"s3://crabby-images/80e8a/80e8a3348915239910ea595482dbeefe7b209837" alt=""
(2)distinct:查询不重复记录
去除年龄字段中重复的
查找性别
data:image/s3,"s3://crabby-images/4d3f4/4d3f4215091cce8fadc0d91510d27b29e074d9b2" alt=""
(3)where根据条件查询
显示name和age 字段 并且要找到age小于20
data:image/s3,"s3://crabby-images/7b5c7/7b5c7ce01f5aed796dddaa71114f359a566b4f3f" alt=""
(4) and且、or或 根据多个条件查询
data:image/s3,"s3://crabby-images/967e7/967e7bc8aab3d5c10cb9e19e22dc0f904d9ce138" alt=""
(5) in显示已知值的资料
显示学号为1,2,3,4的学生记录
data:image/s3,"s3://crabby-images/2512f/2512f40d2c841c1040dfd77361d4eca4aa85c84d" alt=""
显示班级为1和3的学生记录
data:image/s3,"s3://crabby-images/b3068/b306832db8dc5ddee61f1115798e8faa47b1953a" alt=""
(6)between显示两个值范围内的资料
显示学生姓名在Ding Dian和Hua Rong中的学生记录
data:image/s3,"s3://crabby-images/4a89b/4a89b67fc5304be0d5e191b5e51752549567f769" alt=""
显示学生号码id在2-5 的信息
data:image/s3,"s3://crabby-images/aac46/aac46cb698210b7c4e6b1c04d911e0fa23c37bfb" alt=""
显示学生年龄在20-35之间的信息,不需要表中一定有该字段,只会将20到25 已有的都显示出来
data:image/s3,"s3://crabby-images/66d4a/66d4a35e74e2837792afb26a1966132ec230bf94" alt=""
(7)like+通配符 模糊查询
查找名字以l开头的学生记录
查找名字包含ang的学生记录
data:image/s3,"s3://crabby-images/0fd4b/0fd4b0633658a1f851930dd4195f9a40a7d44808" alt=""
查找名字第二个字母为i,第三个字母为a的学生记录
data:image/s3,"s3://crabby-images/cce41/cce41ae23ff6185219ecb33ddcf90ce8ee6e1a96" alt=""
(8)order by:按关键字排序
按学生的年龄正向排序显示年龄和姓名字段
data:image/s3,"s3://crabby-images/19652/1965274cbcd0cb2a334f3a523a1765821f0f3c91" alt=""
按学生的年龄反向排序显示年龄和姓名字段
data:image/s3,"s3://crabby-images/7be53/7be5306d476be19a1ef58bf5e7ab69aefced28ef" alt=""
显示name、age和classid字段的数据 并且只显示classid字段为1 的 并且以age字段排序
data:image/s3,"s3://crabby-images/2bed8/2bed84d9093c53be44cc9e31df5eaff5affe3f36" alt=""
3.SQL函数
数学函数
(1)返回-2的绝对值
(2) 随机生成一个数
data:image/s3,"s3://crabby-images/08b7e/08b7e7fcb4fa6e22ab1ff3ad4979cde3c5aa2011" alt=""
(3)随机生成排序
data:image/s3,"s3://crabby-images/2b2d4/2b2d48a1dafe605b1d50985f01cf8ab9ff26d6fd" alt=""
(4)返回7除以2以后的余数
data:image/s3,"s3://crabby-images/f1c50/f1c507540e6724ca8025820a334fe4f5bb627687" alt=""
(5)返回2的3次方
data:image/s3,"s3://crabby-images/b9194/b9194ad74fa89d6023342cf8764abbf9bb9f94cb" alt=""
(6)返回离2.6最近的数
data:image/s3,"s3://crabby-images/5d98f/5d98fc4cb5243a23ac6d655cffbfcac720f421cc" alt=""
(7)返回离2.4最近的数
data:image/s3,"s3://crabby-images/f5454/f54548ec3f434b0d106c981eb58fe4be901befb8" alt=""
(8)保留2.335321的3位小数四舍五入后的值
data:image/s3,"s3://crabby-images/7c408/7c408e42ebf9561336460820f7f0946928a83b72" alt=""
(9)返回数字 2.335321 截断为2位小数的值
data:image/s3,"s3://crabby-images/96f04/96f04a82f81d8632d56ac4df5c50c99df451759b" alt=""
(10)返回大于或等于2.335321 的最小整数
data:image/s3,"s3://crabby-images/75f9d/75f9d568fa21060283f5cd18fddad6e5541c6e16" alt=""
(11)返回小于或等于 2.335321 的最大整数
data:image/s3,"s3://crabby-images/9bd89/9bd8950028b8096cf65f1834a50f04eabfcb3287" alt=""
(12)返回集合中最大的值
data:image/s3,"s3://crabby-images/23712/23712de668d68f04a61d8af43517cce4f75a4e7f" alt=""
(13)返回集合中最小的值
data:image/s3,"s3://crabby-images/dc440/dc440020369a37b1545a2eedeea3886640b500c6" alt=""
聚合函数
(14)求表中年龄的平均值
(15)求表中年龄的总和
data:image/s3,"s3://crabby-images/9ea54/9ea54d69c5e06fb983089e8b7b16194dec5837a4" alt=""
(16)求表中年龄的最大值
data:image/s3,"s3://crabby-images/d43e6/d43e65e1eedcaa0abe9d514ca86fd6615e99371f" alt=""
(17)求表中年龄的最小值
data:image/s3,"s3://crabby-images/7d298/7d298752f53ccca83376477043a70e23f79cb308" alt=""
(18)求表中有多少班级字段非空记录
data:image/s3,"s3://crabby-images/6b70c/6b70c34efc007a2e8681cac5cbd92833f9e7f66c" alt=""
(19)求表中有多少条记录
data:image/s3,"s3://crabby-images/bde16/bde1680f7b7a02438098d0b3e19469660089f736" alt=""
(20)看空格字段是否会被匹配
data:image/s3,"s3://crabby-images/05a8b/05a8b993ee2b263a2229e5f4f384f5de2df85175" alt=""
字符串函数
(21)从名字开头的开始,移除Sun Dasheng中的Sun显示
(22)计算出字段中记录的字符长度
data:image/s3,"s3://crabby-images/3bee3/3bee3b216c78b81e10fa75a2f108b6810aef7a78" alt=""
(23)查看名字里包含an的记录
data:image/s3,"s3://crabby-images/ddb74/ddb743a5c289956a40bc793b7da386f6ff24aef2" alt=""
(24)将an替换成hh显示出来
(25)将name,classid字段拼接成一个字符串
data:image/s3,"s3://crabby-images/ed206/ed2067e90a667cf579b3c5f8063eef5ef4e4999c" alt=""
(26)截取第3个字符往后
data:image/s3,"s3://crabby-images/53a0a/53a0a3469ef66d4a1ade201e7cc038c2565f7edb" alt=""
(27)截取第2个字符往后的两个字符
data:image/s3,"s3://crabby-images/1017f/1017f9e114f456d384ea39d5364f12c51e922ccc" alt=""
4.SQL高级操作
(1)group by查询结果进行汇总分组
求各个班的年龄总和
data:image/s3,"s3://crabby-images/a5d63/a5d6312adf5e69e98ea5d5ba19f653249c99410c" alt=""
求各个班的平均年龄
data:image/s3,"s3://crabby-images/e287d/e287d8897bd2a6a521d4d77ad07f798f081c2d87" alt=""
根据年龄查看每个班的人数
data:image/s3,"s3://crabby-images/16c74/16c74d2974d17008d29831944ae79d48e697caf0" alt=""
(2)having过滤返回的记录集
查看各个班的平均年龄在22以上的班级
data:image/s3,"s3://crabby-images/426b9/426b9ed6e299aac4cc1646849df501116420465e" alt=""
(3)as别名
data:image/s3,"s3://crabby-images/6dbc1/6dbc17b86c0c02d5fbc4c5bf3f40b7aca1b28857" alt=""
(4)连接查询
创建scores表
data:image/s3,"s3://crabby-images/e9c9e/e9c9e370ae8af905b7407063b2fa18a02ec823b6" alt=""
inner join(等值相连)只返回两个表中联结字段相等的行
data:image/s3,"s3://crabby-images/07b5e/07b5e29d9b0a1855247d3bf8e4154f02703c1138" alt=""
left join(左联接)返回包括左表中的所有记录和右表中联结字段相等的记录
data:image/s3,"s3://crabby-images/ceb2f/ceb2f5fadac6a7bd7d94d26f4846309df7946328" alt=""
right join(右联接)返回包括右表中的所有记录和左表中联结字段相等的记录
data:image/s3,"s3://crabby-images/fcbb3/fcbb3afa1cecea04d1d7b2a0d93ef0520a112e05" alt=""
(5)子查询
查询学生学号为1的得分总和
data:image/s3,"s3://crabby-images/8c2c3/8c2c3e2ff3ca0a1f63a6b0b511750f3906f0cf1b" alt=""
5.主键表和外键表
(1)创建主表和从表
data:image/s3,"s3://crabby-images/e2310/e2310b82f704b44769203043ddf9916e024c1b88" alt=""
(2)为主表master添加一个主键约束
data:image/s3,"s3://crabby-images/f6e69/f6e694bc89b5a4fc3cc18ddec6f7fc4ec2e152d8" alt=""
(3)为从表slave表添加外键
(4)使用查询表语句结构命令查看外键关联
(5)插入新的数据记录时,要先主表再从表
data:image/s3,"s3://crabby-images/7f9b6/7f9b69a6c6644be49c9d651dbb3c3e558341fcc8" alt=""
(6)删数数据记录时,要先从表再主表,也就是说删除主键表时必须先删除其他与之关联的表。
bash
drop tables slave;
drop tables master;
(7)要删除外键约束字段先删除外键约束,再删除外键名
data:image/s3,"s3://crabby-images/e85c9/e85c913eb938338b204d618ab0b0ad0c3c5f3232" alt=""
data:image/s3,"s3://crabby-images/1c22c/1c22c6eb213269fe418c14c23e2d81c43b7b93d4" alt=""
三、总结
克隆表将数据表的数据记录生成到新的表中.
清空表删除表内的所有数据。
group by查询结果进行汇总分组,having用来过滤由group by语句返回的记录集,通常与group by语句联合使用。