mysql经典面试题
数据库优化:
这个优化法则归纳为5个层次:
1、 减少数据访问(减少磁盘访问)
2、 返回更少数据(减少网络传输或磁盘访问)
3、 减少交互次数(减少网络传输)
4、 减少服务器CPU开销(减少CPU及内存开销)
5、 利用更多资源(增加资源)
我们一般在什么字段上建索引?
这是一个非常复杂的话题,需要对业务及数据充分分析后再能得出结果。主键及外键通常都要有索引,其它需要建索引的字段应满足以下条件:
1、字段出现在查询条件中,并且查询条件可以使用索引;
2、语句执行频率高,一天会有几千次以上;
3、通过字段条件可筛选的记录集很小,那数据筛选比例是多少才适合?
这个没有固定值,需要根据表数据量来评估,以下是经验公式,可用于快速评估:
小表(记录数小于10000行的表):筛选比例<10%;
大表:(筛选返回记录数)<(表总记录数*单条记录长度)/10000/16
单条记录长度≈字段平均内容长度之和+字段数*2
-- 当前时间
select CURTIME();
-- 当前日期
select NOW();
-- 查询当天数据
select * from 表名 where TO_DAYS(时间字段)=TO_DAYS(NOW());
-- 查询本周的数据
SELECT * FROM 表名 WHERE YEARWE--EK(date_format(时间字段,'%Y-%m-%d')) = YEARWEEK(now());
-- 最近7天
SELECT * FROM 表名 where date_sub(curdate(), INTERVAL 7 DAY) <= date (时间字段);
-- 查询本月的数据
select * from 表名 where DATE_FORMAT(时间字段,'%Y%m') =DATE_FORMAT(CURDATE(),'%Y%m');
-- 上一月
SELECT * FROM 表名 WHERE PERIOD_DIFF( date_format( now( ) , '%Y%m' ) , date_format( 时间字段名, '%Y%m' ) ) =1
/*-----------------------------------------第一大题--------------------------------------------------*/
S(SO,SN,SD,SA) 学号,学员姓名,所属单位,学员年龄
C(CO,CN)课程编号,课程名称
SC_1(SO,CO,G)学号,所选修的课程编号,学习成绩
/*1 查询选修课程名为‘税收基础的学员学号和姓名’*/
--方法一:连接查询
SELECT s.SO,s.SN FROM S s,C c,sc_1 sc
where c.CN='税收基础'
and s.so=sc.SO and sc.co=c.CO;
--方法二:嵌套查询
SELECT so,sn from s
where so in(
SELECT so from sc_1 where co in (
SELECT co from c where cn='税收基础'
)
)
/*2 查询选修课程编号为‘c002’学员姓名和所属单位’*/
--方法一:连接查询
SELECT s.SN,s.SD from s s,c c,sc_1 sc
where c.co='c002'
and c.co=sc.CO and s.so=sc.so;
--方法二:嵌套查询
SELECT sn,sd from s
where so in(
SELECT so from sc_1 where co IN (
SELECT co from c
where co='c002'
)
)
/*3 查询不选修课程编号为‘c005的学员姓名跟所属单位’*/
SELECT sn,sd from s
where so not IN
(select so from sc_1 WHERE co='C005');
/*4 查询选修全部课程学员姓名和所属单位’*/
SELECT sn,sd from s
where so in
(
SELECT so from sc_1
GROUP BY so
HAVING COUNT(co)=(SELECT COUNT(co) FROM c)
);
/*5 查询选修了课程的学员人数*/
SELECT COUNT(DISTINCT so) as 选修课程人数 from sc_1;
/*6 查新选修课程大于5门的学员姓名跟所属单位*/
SELECT sn,sd from s
where so IN
(SELECT so from sc_1
GROUP BY so
HAVING COUNT(so)>5
);
/*-----------------------------------------第二大题--------------------------------------------------*/
S(SNO,SNAME)学生关系,SNO学号,SNAME姓名
C(CNO,CHAME,CTEACHER)课程关系,CNO课程号,CHAME课程名,任课老师
SC(SNO,CNO,SCGRADE)选课关系,SCGRADE成绩
/*第一题 找出没有选修过李明老师的课程的所有学生*/
SELECT s.sname FROM student s
where sno not IN
(SELECT DISTINCT(sc1.cno) from class c,sc sc1,student s
where c.cno=sc1.cno and sc1.sno=s.sno
and c.cteacher='李明'
);
/*第二题 列出有两门以上不及格课程的学生姓名跟平均成绩*/
select s.sname as 学生姓名,avg(ssc.scgrade) as 平均成绩 from student s
,sc ssc,(select sno from sc
where scgrade<60
GROUP BY sno
HAVING COUNT((cno)>=2)) a
where s.sno=a.sno and ssc.sno=a.sno
GROUP BY s.sno,s.sname;
/*第三题 列出既学过1号课程又学过2号课程的学生姓名*/
Select s.sno,s.sname FROM student s
where s.sno in
(
Select sc2.sno FROM sc sc2,class c2 Where sc2.cno=c2.cno AND c2.cno IN('1','2')
GROUP BY sc2.sno
HAVING COUNT(DISTINCT c2.cno)=2
);
/*第四题 列出1号课成绩比2号该门课成绩高的所有学生学号*/
SELECT sc1.sno as 学生编号 from sc sc1,sc sc2 where
sc1.cno='1'
and sc2.cno='2'
and sc1.sno=sc2.sno
and sc1.scgrade>sc2.scgrade;
/*第五 列出1号课成绩比2号同学课成绩高的所有学生学号以及1号跟2号课成绩*/
SELECT sc1.sno as 学生编号,sc1.scgrade as 语文成绩,sc2.scgrade as 数学成绩 from sc sc1,sc sc2 where
sc1.cno='1'
and sc2.cno='2'
and sc1.sno=sc2.sno
and sc1.scgrade>sc2.scgrade
mysql经典面试题的更多相关文章
- 数据库MySQL经典面试题之SQL语句
数据库MySQL经典面试题之SQL语句 1.需要数据库表1.学生表Student(SID,Sname,Sage,Ssex) --SID 学生编号,Sname 学生姓名,Sage 出生年月,Ssex 学 ...
- MySQL 经典面试题
MySQL 面试 1 存储过程 什么是存储过程 存储过程是一些编译好的SQL语句 因为系统在调用SQL的时候比较浪费时间,所以之前先将一些基本的额SQL语句代码进行编译(对单表或多表的增删改查),然后 ...
- 面试BAT前先搞定这18道MySQL经典面试题(含答案解析)
一.MySQL的复制原理以及流程 (1)复制基本原理流程 1. 主:binlog线程——记录下所有改变了数据库数据的语句,放进master上的binlog中: 2. 从:io线程——在使用start ...
- mysql经典面试题之学生成绩表
需要数据库表1.学生表 Student(SID,Sname,Sage,Ssex) --SID 学生编号,Sname 学生姓名,Sage 出生年月,Ssex 学生性别 2.课程表 Course(CID, ...
- 100道MySQL数据库经典面试题解析(收藏版)
前言 100道MySQL数据库经典面试题解析,已经上传github啦 https://github.com/whx123/JavaHome/tree/master/Java面试题集结号 公众号:捡田螺 ...
- php经典面试题与答案(转先锋教程网)
php经典面试题与答案 时间:2016-02-29 16:06:23来源:网络 导读:php经典面试题与答案,包括腾讯php面试题.百度php面试题.新浪php面试题等 php面试题及答案 1,禁 ...
- Linux 经典面试题
[Linux 经典面试题] 1. 在Linux系统中,以 文件 方式访问设备 . 2. Linux内核引导时,从文件 /etc/fstab 中读取要加载的文件系统. 3. Linux文件系统中每个文 ...
- 经典面试题:从 URL 输入到页面展现到底发生什么?
前言 打开浏览器从输入网址到网页呈现在大家面前,背后到底发生了什么?经历怎么样的一个过程?先给大家来张总体流程图,具体步骤请看下文分解! 本文首发地址为GitHub 博客,写文章不易,请多多支持与关注 ...
- MySQL开发面试题
……继上一篇MySQL的开发总结之后,适当的练习还是很有必要的…… SQL语法多变,不敢保证唯一,也不敢保证全对,如果错误欢迎指出,即刻修改. 一.现有表结构如下图 TABLENAME:afinfo ...
随机推荐
- MyBatis主键生成器SelectKeyGenerator(三)
前面两篇博客我们介绍了MyBatis主键生成器KeyGenerator(一)和MyBatis主键生成器Jdbc3KeyGenerator(二),接下来我们介绍SelectKeyGenerator, 如 ...
- iOS中 MPMoviePlayer 实现视频音频播放 作者:韩俊强
ios播放视频文件一般使用 MPMoviePlayerViewController 和 MPMoviePlayerController.前者是一个view,后者是个Controller.区别就是 MP ...
- 【一天一道LeetCode】#86. Partition List
一天一道LeetCode 本系列文章已全部上传至我的github,地址:ZeeCoder's Github 欢迎大家关注我的新浪微博,我的新浪微博 欢迎转载,转载请注明出处 (一)题目 Given a ...
- MySQL数据库写入图片并读取图片显示到JLabel上的详解
相较于Oracle,MySQL作为一个轻量级的开源的数据库,可谓是大大简化了我们的操作.这次我就来写一个关于数据库存入图片,获取图片的例子吧,也为了今后的复习使用.(我们一般采取存入路径的方式,而不是 ...
- MySQL学习笔记_5_SQL语言的设计与编写(上)
SQL语言的设计与编写(上) 一.SQL语句分类 数据定义语言(DDL): 用于定义和管理数据对象,包括数据库.数据表.视图.索引等.例如:CREATE.DROP.ALTER等语句. 数据操作语言(D ...
- linux进程管理之进程创建
所谓进程就是程序执行时的一个实例. 它是现代操作系统中一个很重要的抽象,我们从进程的生命周期:创建,执行,消亡来分析一下Linux上的进程管理实现. 一:前言 进程管理结构; 在内核中,每一个进程对应 ...
- [转].NET程序破解仅需三步
近期开发公司商城,为了简化开发用了V5Shop网店程序.本来预计一个月完工,哪知道出现一堆问题大大增加了我的工作量(早知道还不如全部自己写了). 破V5Shop真不地道,说是免费的,结果程序一大堆问题 ...
- JavaScript进阶(三)常见工具(校验、通用)
JS常见工具(校验.通用) // 姓名校验 var checkName = function(name) { // 收货人姓名校验(准则:姓名为2-4汉字) var regu = /^[\u4E00- ...
- 蘑菇街Android组件与插件化
插件化的基石 -- apk动态加载 随着我街业务的蓬勃发展,产品和运营随时上新功能新活动的需求越来越强烈,经常可以听到"有个功能我想周x上,行不行".行么?当然是不行啦,上新功能得 ...
- 学习C++模板,类模板
当我们使用向量时,会经常使用形如:vector<int> a的式子.这个表达式就是一个类模板实例化的例子,vector是一个类模板,我们给他传递模板参数(见<>里),然后创建一 ...