*号是全部的意思
格式: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;
- 用一条 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,即非关系型数据库,也是缓存数据库,即将数据存储在缓存中,缓存的读取速度快,能够大大的提高运行效率,但是保存时间有限