`
you_java
  • 浏览: 96288 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

sql 面试题

阅读更多


题目一、

id sname smoney sprovince
1 zhangsan 2098 A
2 lisi 3000 B
3 wangwu 6789 C
4 liumazi 4587 C
5 dongjiu 3298 B
6 shiga 4567 A


id:合同id  sname:姓名     smoney :业绩     sprovince:地区


第一道:显示出  业绩 大于同一地区平均值的 合同id  姓名 地区 业绩


第二道:把同一地区的  平均业绩 地区 插入到新表中 (新表只包含两个字段即:平均业绩 地区)


答案:

第一道题答案:

第一种写法,select t1.*,t2.avg_smoney from hetong t1,

(select avg(smoney) avg_smoney,sprovince from hetong group by sprovince) t2

where t1.sprovince = t2.sprovince and t1.smoney>t2.avg_smoney;

第二种写法,select t1.*,t2.avg_smoney from hetong t1 join

(select avg(smoney) avg_smoney,sprovince from hetong group by sprovince) t2

on(t1.sprovince = t2.sprovince and t1.smoney>t2.avg_smoney);

第三种写法,select a.* from hetong a 

where a.smoney > (select avg(t.smoney) from hetong t where t.sprovince = a.sprovince);


第二道题答案:

create table ht2 as

(select avg(smoney) avg_smoney,sprovince from hetong group by sprovince);


题目二、

原题大致是这样 合同表 cid主键 
cid  Region(区域)   Saler(销售员)  Money(合同金额) 
  1         北京           杨建               100 
  2         上海           社长               200 
  3         杭州           副团               500 
  4         上海           社长               200 
  5         上海           杨建               400 
  6         北京           社长               300 
  7         北京           杨建               200 
  8         杭州           副团               100 


1. 查询每个区域有多少个销售人员并按区域倒叙排列 
2. 查询所有相同区域中合同金额最少的区域 
3. 查询表中合同金额小于所在区域平均合同金额的合同id 


答案:

第一道题答案,select t.region,count(*) from

(select count(saler) cc,region,saler from com group by region,saler order by region desc) t

group by region;


第二道题答案,select min(money),region from com group by region;


第三道题答案,select c.* from com c join

(select avg(money) avg_money,region from com group by region) c1

on(c.region=c1.region and c.money<c1.avg_money)

 

题目三、

1、select * from schools 

 

class name sex
一班 张三 M
一班 李四 M
一班 王五 M
一班 cc F
一班 mm F
二班 小明 M
二班 小河 F

现在要查询出 男女人数相等的班级

 

答案:select tem.class from(

select class, 

(select count(sex) from schools s1 where s1.sex='M' and s1.class=s.class) as mcount,

(select count(sex) from schools s1 where s1.sex='F' and s1.class=s.class) as fcount 

from schools s group by class

) tem where tem.mcount=tem.fcount;

 

2、select * from grade

 

姓名    科目  成绩

王五     语文  80

李四     语文  90

李四     数学  80

李四     英语  70

张三     语文  80

张三     数学  80

张三     英语  90

要求这么显示:

 

科目 语文 数学 英语
王五 80 NULL NULL
李四 90 80 70
张三 80 80 90

 

答案:select name as 科目,

(select score from grade g1 where g1.name=g.name and subject='语文') as 语文,

(select score from grade g1 where g1.name=g.name and subject='数学') as 数学,

(select score from grade g1 where g1.name=g.name and subject='英语') as 英语 from grade g group by name

 

题目四、

数据库 ORACLE

 

T表:(字段:ID,NAME,ADDRESS,PHONE,LOGDATE)

E表:(字段:NAME,ADDRESS,PHONE)

1. 将表T中的字段LOGDATE中为2001-02-11的数据更新为2003-01-01,请写出相应的SQL语句。(该字段类型为日期类型)--注意可能包含多条记录


2. 请写出将表T中NAME存在重复的记录都列出来的SQL语句(按NAME排序)


3. 请写出题目2中,只保留重复记录的第一条,删除其余记录的SQL语句(即使该表不存在重复记录)


4. 请写出将E表中的ADDRESS、PHONE更新到T表中的SQL语句(按NAME相同进行关联)


5. 请写出将T表中第3~5行数据列出来的SQL语句


答案:

1.update t set logdate=to_date('2003-01-01','YYYY-mm-dd') where logdate=to_date('2001-02-11','YYYY-mm-dd');


2.select count(*),name from t group by name having count(*)>1 order by name;

--

select * from t 

where name in (select name from t group by name having count(*)>1)

order by name;


3.select * from

(select t.*,row_number() over(partition by name order by name) rn from t)

where rn = 1;

--

delete from t where rowid not in(select min(rowid) from t group by name);


4.update t set(address,phone)=(select address,phone from e where e.name=t.name) 

where exists(select e.name from e where t.name=e.name);


update t set(address,phone)=(select address,phone from e where e.name=t.name) 

where t.name in(select name from e);


5.select tt.*,rownum n from(

select t.*,rownum rn from (select * from t order by id) t where rownum<=5

) tt where rn>=3


 

 

题目五、

数据库SQL

/*

1. 在表A中有数据

ID    MO

1    Y

2    N

请用一个SELECT 语句写出,如果MO的值为“Y”,返回“YES”,为N返回“NO”

效果如下:

ID    MO

1    YES

2    NO

*/

答案:

select id,mo=case 

when mo='y' then 'yes'

when mo='n' then 'no'

end from az


2. 在表A中查询出自动增长列中31到40之间的数据(注意可能不是连续的)

答案:select * from A where id between 31 and 40


3. 有一个表table中有一个自动增长字段ID,如果在存储过程中向这个表插入一条记录后,如何获得新记录的ID.(写出获取新记录ID的函数即可)

答案:

create function c_currentId()

returns int

as

begin

declare @lastId int

select @lastId=max(id) from t_1

return (@lastId)

end


select test.dbo.c_currentId() as '当前C表中最新的编号'


4. having的用法, 是用来做什么的

答案:having用来对group by 分组后的记录进行过滤。


5. sql中的什么函数可以转换为时间

答案:

select convert(datetime,'2000/01/01')

select cast('2001/02/02' as datetime)


6. 查询数据放入一张临时表

答案:

select * into #A from a

select * from #A

 

分享到:
评论

相关推荐

    经典sql面试题

    ### 经典SQL面试题解析 #### 颇具挑战性的SQL面试题——删除冗余记录 **题目背景与分析** 在本题中,我们面对的是一个常见的问题:如何有效地处理数据库中的冗余数据。在实际应用中,由于各种原因(如数据导入...

    sql面试题(适合软件测试)

    根据提供的文件内容,我们可以整理出以下几个SQL面试题及其解答,这些问题主要聚焦于SQL查询技巧、数据处理以及数据结构的理解。 ### 1. 查询每门课都大于80分的学生姓名 **题目描述**:给定一张成绩表,其中包含...

    sql面试题很详细的sql语句面试题

    SQL面试题详解 本资源旨在总结和详细解释SQL面试题中的各种问题和解决方案,并对每个问题进行了详细的解释和分析。 一、查询每门课都大于80分的学生姓名 问题:使用一条SQL语句查询出每门课都大于80分的学生姓名...

    尚硅谷大数据技术之企业SQL面试题_大数据_sql_尚硅谷sql_doc_

    "尚硅谷大数据技术之企业SQL面试题"这个资料集显然针对的是准备面试的求职者,特别是那些希望在大数据环境中运用SQL技能的角色。这份文档可能是由尚硅谷——一个知名的IT教育机构提供的,旨在帮助学习者掌握SQL在...

    SQL面试题.doc

    SQL 面试题 SQL(Structured Query Language)是一种特殊-purpose 编程语言,用于管理关系数据库管理系统(RDBMS)。SQL 面试题是 IT 行业中非常重要的一部分,涵盖了数据库管理、数据查询、数据操作等方面的知识。...

    java 面试题基础题,sql 面试题 带答案

    二、SQL 面试题 1. **SQL 数据类型:** 包括数值类型(如 INT、FLOAT)、字符串类型(如 VARCHAR、CHAR)、日期时间类型(如 DATE、TIMESTAMP)等。 2. **SELECT 语句:** 用于从数据库中选择数据,如 `SELECT *...

    oraclesql面试题

    从给定的Oracle SQL面试题中,我们可以提炼出多个关键知识点,这些知识点涵盖了SQL查询、数据操作、表结构设计以及Oracle数据库的一些高级特性。以下是对这些知识点的详细解析: ### 1. 数据分组与聚合函数 在第一...

    50道SQL面试题

    ### SQL面试题解析 #### 题目1: 查询课程编号为001的成绩高于课程编号为002的学生学号。 ```sql SELECT a.S# FROM (SELECT S#, score FROM SC WHERE C# = '001') a, (SELECT S#, score FROM SC WHERE C# = '002') ...

    非常详细的sql面试题

    SQL 面试题详解 本资源摘要信息将对给定的 SQL 面试题进行详细的解释和分析,涵盖了选择题和填空题两部分。这些问题涉及到 SQL 基础知识、数据库理论、数据结构、算法设计等方面。 选择题 1. 下面叙述正确的是___...

    几个SQL面试题及答案.sql

    几个SQL面试题及答案.sql

    经典T-SQL面试题

    ### 经典T-SQL面试题解析 #### 题目一:创建空表与条件筛选 **原题描述**:"使用`SELECT INTO`语句从`tb_amount`表中选择所有列到新表`tb_temp`,但在选择时加入一个永远不成立的条件(`1&lt;&gt;1`),确保`tb_temp`为空...

    SQL面试题4(不错).doc

    根据给定文件中的标题“SQL面试题4(不错).doc”、描述“SQL面试题(不错),比较详细,可以值得参考。”以及标签“sql”,我们可以看出这份文档主要聚焦于SQL语言的应用,尤其是针对面试场景下的题目解答。下面将...

    校招sql 面试题

    ### SQL面试题解析 #### 背景介绍 在IT行业的招聘过程中,SQL技术作为数据处理的核心工具之一,经常被用作考核应聘者能力的重要环节。对于即将步入职场的应届毕业生来说,掌握一定的SQL技能是必不可少的。下面将对...

    sql面试题精选实例

    【SQL面试题精选实例】 在SQL面试中,掌握各种查询技巧和高级操作是至关重要的。以下是一些典型的SQL面试问题及解题思路: 1、查询“001”课程比“002”课程成绩高的所有学生的学号: 这个问题通过子查询比较两个...

    SQL面试题(很全,带答案)

    根据给定的文件标题、描述、标签以及部分内容,我们可以从中提炼出以下详细的IT知识点,主要聚焦于SQL语言的基础操作及面试常考知识点: ### SQL语言基础分类与功能 #### 数据定义语言(DDL) - `CREATE DATABASE`:...

    sql面试题收集.pdf

    SQL面试题收集 SQL面试题收集是指通过收集和整理SQL相关问题,帮助开发人员和数据库管理员备战面试和工作中遇到的挑战。本文档汇总了多种表连接方式,包括等连接、非等连接、自连接、外连接(左、右、全)等,并对...

    2018_BAT的55道sql面试题

    在BAT(百度、阿里巴巴、腾讯)等互联网大公司中,SQL面试题是技术面试的重要组成部分,因为掌握SQL是任何数据库工程师或数据分析师的基础技能。以下是一些常见问题的详细解答: 1. **ID自增主键**:在MySQL中,...

    pl/sql面试题,很全面

    SQL 和 PL/SQL 面试题涵盖了数据库查询、聚合函数、条件判断以及日期处理等多个方面。下面是对这些面试题的详细解析: 1. 题目要求统计每天的胜利场次(胜)和失败场次(负)。三种解决方案都利用了 `GROUP BY` ...

    sql面试题,java面试题

    首先,让我们关注SQL面试题。SQL(Structured Query Language)是用于管理关系数据库的标准语言,包括数据查询、更新、插入和删除等操作。常见的SQL面试题涵盖以下几个方面: 1. 数据库基本概念:理解数据库、表、...

    SQL面试题汇总.pdf

    在SQL面试题(1)的答案中,使用了`RIGHT JOIN`将`testtable1`和`testtable2`进行连接。右连接返回所有右表(在这里是`testtable2`)的记录,即使在左表(这里是`testtable1`)中没有匹配的记录。对于左表中没有...

Global site tag (gtag.js) - Google Analytics