Mysql高级语句

导入文件至数据库

mysql> source /backup/test.sql;          #将文本本导入  source  加文件路径

1、select

显示表格中的一个或者多个字段中所有的信息

select 字段名  from 表名;

select * from 表名;

2、distinct 

查询不重复记录,只对单个字段去重

select distinct 字段 from 表名﹔
​
#示例:去除年龄字段中重复的
select distinct age from students;

3、where

条件查询

select '字段' from 表名  where 条件
​
#示例:显示name和age 并且要找到age小于20
select name,age from students where age < 20;

4、and 且 ; or 或

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;

5、in

显示已知值的资料

select 字段名  from 表名 where 字段 in ('值1','值2'....);
​
#示例1:显示学号为1,2,3,4的学生记录
select * from students where ID in (1,2,3,4);

6、between

显示两个值范围内的资料

select 字段名  from 表名 where 字段 between  '值1' and '值2';
包括and两边的值
​
#示例:显示学生姓名在Ding Dian和Hua Rong中的学生记录
select * from students where name between 'ding dian' and 'Hua Rong';

7、like 通配符

通配符通常是和 like 一起使用

select 字段名  from 表名 where 字段 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 的字符串

8、order by

order by 按关键字排序

select 字段名  from 表名 where 条件 order by 字段 [asc,desc];
asc :正向排序
desc :反向排序
默认是正向排序
​
#示例:按学生的年龄正向排序显示年龄和姓名字段
select age,name from students order by age;

9、函数

数学函数

函数含义
abs(x)返回x 的绝对值
rand()返回0到1的随机数
mod(x,y)返回x除以y以后的余数
power(x,y)返回x的y次方
round(x)返回离x最近的整数
round(x,y)保留x的y位小数四舍五入后的值
sqrt(x)返回x的平方根
truncate(x,y)返回数字 x 截断为 y 位小数的值
ceil(x)返回大于或等于 x 的最小整数
floor(x)返回小于或等于 x 的最大整数
greatest(x1,x2.....)返回返回集合中最大的值
least(x1,x2..........)返回返回集合中最小的值

聚合函数

函数含义
avg()返回指定列的平均值
count()返回指定列中非 NULL 值的个数
min()返回指定列的最小值
max()返回指定列的最大值
sum(x)返回指定列的所有值之和
​
#示例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);

字符串函数

函数描述
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 反转
10、group by 

对group by 后面的字段的查询结果进行汇总分组,通常是结合聚合函数一起使用的

group by 有一个原则,就是select 后面的所有列中,没有使用聚合函数的列必须出现在 group by 的后面。

select 字段1,sum(字段2) from 表名 group by 字段1;
​
#示例:求各个班的年龄总和
select classid,sum(age) from students group by classid;

11、having

having:用来过滤由group by语句返回的记录集,通常与group by语句联合使用

having语句的存在弥补了where关键字不能与聚合函数联合使用的不足。如果被SELECT的只有函数栏,那就不需要GROUP BY子句。

要根据新表中的字段,来指定条件

SELECT 字段1,SUM("字段")FROM 表格名 GROUP BY 字段1 having(函数条件);
​
#示例:查看各个班的平均年龄在30以上的班级
select classid,avg(age) from students group by classid having avg(age) > 30;

12、别名

栏位別名 表格別名

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;

13、子查询

连接表格,在where子句或having子句中插入另一个SQL语句

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);

14、连接查询

inner join(等值相连)
只返回两个表中联结字段相等的行
select * from 表1 A, 表2 B where A.相同字段 = B.相同字段;
select * from 表1 A inner join 表2 B on A.相同字段 = B.相同字段; #令表1别名为A,表2别名为B
​
left join(左联接)
返回包括左表中的所有记录和右表中联结字段相等的记录
select * from 表1 A left join 表2 B on A.相同字段 = B.相同字段;
​
right join(右联接)
返回包括右表中的所有记录和左表中联结字段相等的记录
select * from 表1 A right join 表2 B on A.相同字段 = B.相同字段;

create view(视图)

对几个表查询,如连接查询,以查询结果形成视图表,若视图表和原表结构相同,那么也可插入数据。

CREATE VIEW "视图表名" AS "SELECT 语句";
​
#示例:创建视图表,表名为new_students,数据是跟在as后面的select语句,scores表的别名为a,students表的别名为b;将a表和b表等值连接,连接字段为stuid,将a表的score和stuid列显示到新表中为score和stuid;将b表中的name列显示到新表为name
create view new_students as select a.score score,a.stuid stuid,b.name name from scores a inner join students b on a.stuid=b.stuid;
 
#删除视图
drop view new_students;
​

                
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值