zoukankan      html  css  js  c++  java
  • 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

  • 相关阅读:
    HDU
    HDU
    (4)数据--相似性与相异性
    (3)数据--操作
    (2)数据--基本概念
    五、按生命周期划分数据(二)
    五、常用数据类型(一)
    四、坏耦合的原因与解耦(三)
    四、强化耦合(二)
    四、初识耦合(一)
  • 原文地址:https://www.cnblogs.com/hghua/p/13292825.html
Copyright © 2011-2022 走看看