mysql——面试题

*号是全部的意思
格式:inner/left/right/full join ... on
多表查询: SELECT * FROM table1 LEFT JOIN table2 ON table1.id=table2.id JOIN table3 ON table3.id1=table2.id1 and (条件);

查:SELECT 列名 form 表名
增:insert into 表名(列1,列2...) values (值1,值2...)

改:update 表名 set 列=新值 where 列 = 旧值
删:delete from 表名 where 列=值

排序:select 列名 from 表名 order by 列名

降序:asc 升序:desc

模糊查询:like

分组查询:group by

筛选:having

去重:distinct

limit: limit 1,10分页

聚合函数:max/min/avg/count/sum

主键和索引的区别:

1. 主键一定是唯一性索引,唯一性索引并不一定就是主键。 
2. 一个表中可以有多个唯一性索引,但只能有一个主键。
3. 主键列不允许空值,而唯一性索引列允许空值。
4. 索引可以提高查询的速度。

面试题一

请看下面三张表:
学生表(学生id,姓名,性别,分数) )student(s_id, name, sex, score)

班级表(班级id,班级名称) class(c_id, c_name)

学生班级表(班级id,学生id) student_class(s_id,c_id)

1.查询一班得分在80分以上或者等于60,61,62的学生

select s_id,name,score,c_name from student where score>80 or score in(60,61,62) and s_id in(select a.s_id from student_class a,class b where a.c_id=b.c_id and a.c_name='一班');
SELECT s.s_id,s.name,s.score,sc.c_id,c.c_name from student s LEFT JOIN student_class sc on s.s_id = sc.s_id LEFT JOIN class c on sc.c_id=c.c_id where (s.score>80 or s.score in(60,61,62)) and c.c_name='一班';

2.査询所有班级的名称,和所有班中女生人数和女生的平均分。

select count(a.sex),avg(score),c.c_name from student a left JOIN student_class b on  a.s_id=b.s_id LEFT JOIN class c on b.c_id=c.c_id where a.sex ='女' GROUP BY c.c_name;
  1. 用一条 SQL语句查询出每门课都大于 80 分的学生姓名?
  select DISTINCT name from grade where name not in (select name from grade where fenshu <=80)

面试题二
柠檬班第30期学生要毕业了,他们的成绩存放在下表中,现在需要查询每个班的最高分同学,并且显示该同学的名字!

1.先找出每个班的最高分

select class_name, GREATEST(max(Linux),max(Mysql),max(Java)) from tb_lemon_grade GROUP BY class_name; -- GREATEST()横向比较;max()纵向比较

面试题三
简述mysql和redis区别
mysql是关系型数据库,主要用于存放持久化数据,将数据存储在硬盘中,都存在着I/O操作,读取速度较慢。
redis是NOSQL,即非关系型数据库,也是缓存数据库,即将数据存储在缓存中,缓存的读取速度快,能够大大的提高运行效率,但是保存时间有限

详见此链接:https://www.cnblogs.com/zxh1297/p/9394108.html

posted @ 2020-07-13 13:51  不放弃自己  阅读(275)  评论(0编辑  收藏  举报