`
dhaigang
  • 浏览: 15262 次
  • 性别: 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  姓名 地区 业绩

 

 

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

 

 

请写出sql语句

 

分享到:
评论
27 楼 zhanghaocool 2010-02-10  
thinkaw 写道

第一道
SELECT A.ID, A.SNAME, A.SPROVINCE, A.SMONEY
      FROM TT A
     WHERE SMONEY > (SELECT SUM(B.SMONEY) / COUNT(1)
                       FROM TT B
                      WHERE B.SPROVINCE = A.SPROVINCE);
第二道
CREATE TABLE TT_SUM
    AS
    SELECT SPROVINCE, SUM(SMONEY)/COUNT(1) AVG_PRO
      FROM TT
    GROUP BY SPROVINCE;


相关子查询
子查询建表
26 楼 gowish 2010-01-29  
MySQL 5.1通过:
1.SELECT b.smoney,b.sprovince FROM test.biz_tbl b
inner join
(select avg(smoney) as avgMoney,sprovince as sprovinceId from test.biz_tbl a group by sprovince) c
on
b.sprovince = c.sprovinceId
and
b.smoney > c.avgMoney

2.insert into test.avgmoney_tbl (avgmoney,sprovince) SELECT b.smoney,b.sprovince FROM test.biz_tbl b
inner join
(select avg(smoney) as avgMoney,sprovince as sprovinceId from test.biz_tbl a group by sprovince) c
on
b.sprovince = c.sprovinceId
and
b.smoney > c.avgMoney
25 楼 cartonwang 2010-01-28  
cartonwang 写道
第一道:显示出  业绩 大于同一地区平均值的 合同id  姓名 地区 业绩
select t2.id,t2.name,t2.province,t2.money, t1.avg_money
       from t_employee t2, (select t.province, avg(t.money)   avg_money
                           from t_employee t
                           group by t.province) t1
       where t2.province = t1.province
       and t2.money > t1.avg_money
      
第二道:把同一地区的  平均业绩 地区 插入到新表中 (新表只包含两个字段即:平均业绩 地区)

      
      
create table t_employee_avg as (select avg(e.money) avg_money, e.province from t_employee e group by e.province);


-----------------------
看见去年我的回复了,一年过去了,我也开始找工作了。祝福自己能找到自己满意的工作吧!
24 楼 thinkaw 2010-01-06  
第一道:显示出 业绩 大于同一地区平均值的 合同id  姓名 地区 业绩

SELECT A.ID, A.SNAME, A.SPROVINCE, A.SMONEY
      FROM TT A
     WHERE SMONEY > (SELECT SUM(B.SMONEY) / COUNT(1)
                       FROM TT B
                      WHERE B.SPROVINCE = A.SPROVINCE);

            ID SNAME SP SMONEY
    ---------- -------------------- -- ----------

             3 WANGWU  C 6789
             5 DONGJIU B 3298
             6 SHIGA   A 4567

第二道:把同一地区的 平均业绩 地区 插入到新表中 (新表只包含两个字段即:平均业绩 地区)
CREATE TABLE TT_SUM
    AS
    SELECT SPROVINCE, SUM(SMONEY)/COUNT(1) AVG_PRO
      FROM TT
    GROUP BY SPROVINCE;

    SQL> select * from tt_sum;

    SP AVG_PRO
    -- ----------

    A 3332.5
    B 3149
    C 5688

注:自己扩展了几道问题(五道),欢迎浏览。
http://blog.chinaunix.net/u1/53979/showart.php?id=2142515

23 楼 wqmgxj 2010-01-03  
多老的帖子了
22 楼 duqiangcise 2010-01-02  
select a.id,a.sname,a.sprovince,b.avg_money
from table_a a,(
select avg(smoney) avg_money,sprovince
from table
group by sprovince
)b
where a.sprovince=b.sprovince
and a.smoney >b.avg_money

/*
新表table_已存在时的情况,如果新表不存在则按照楼上那些朋友的方法
create
tabe_b(avg_money,sprovince)
*/
insert into tabe_b values(
select avg(smoney),sprovince
from table
group by sprovince
);
21 楼 liran_java 2009-12-29  
明显送分题嘛
20 楼 danny.chiu 2009-11-30  
select t.* from table_name t1 join
( select sprovince, avg(smoney) avg_smoney from table_name group by sprovince ) t2
on (t1.sprovince = t2.sprovince and t1.smoney > t2.avg_smoney);

create table new_table_name as
select avg_smoney, sprovince from
(select avg(smoney) avg_smoney, sprovince from table_name group by sprovince);
19 楼 wxj76 2009-11-10  
select a.*
from test.sqltest a
where a.smoney >
      (select avg(b.smoney) from test.sqltest b group By a.sprovince);



select avg(a.smoney),a.sprovince into test.test1 from test.sqltest a group by a.sprovince;
18 楼 zghaofeng 2009-03-21  
数据库为mysql5
表名为sales


1:
select id,sname,s.sprovince,avg_money
  from sales s join ( select avg(smon
ey) avg_money,sprovince from sales group by sprovince ) t
  on(s.sprovince=t.sprovince and s.smoney > t.avg_money);

2:
create table avg_money (select avg(smoney) avg_money,sprovince from sales
group by sprovince);
17 楼 qinglin876 2009-03-19  
Sybase 中可以如下实现
1.select id,name,province from TETONG as t1 where money>(
select avg(money)
from TETONG as t2
where t1.province=t2.province
group by t2.province
)

2.select avg(money) money,province into TETONG_NEW
from TETONG group by province
16 楼 rainerliu 2009-03-09  
1. 查询每个区域有多少个销售人员并按区域倒叙排列
2. 查询所有相同区域中合同金额最少的区域
3. 查询表中合同金额小于所在区域平均合同金额的合同id

1.select c.region,count(c.saler) from contract c group by c.region order by c.region desc
2.select c.region,min(s.money) from contract c group by c.region
3.select c.cid from contract c,(select cc.region,avg(cc.money) money from contract cc group by cc.region) c2 where c.region=c2.region and c.money<c2.money;

大家帮忙看看有没有问题....
15 楼 pengjian0924 2009-03-08  
xialiang19851204 写道
这个是在知春路那边,我去笔试过,一共5到sql题目 题目出的还可以。答了1个半小时 然后让你回去等消息 

原题大致是这样 合同表 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


1.
select t.region, count(t.saler)
  from (select region, saler, count(saler)
          from test2
         group by region, saler
         order by region desc) T
group by t.region
2.
select region,min(money) from test2 group by region;
3.
select a.cid
  from test2 a
where money < (select avg(money)
                  from test2 b
                 where a.region = b.region
                 group by region)
14 楼 xialiang19851204 2009-03-03  
这个是在知春路那边,我去笔试过,一共5到sql题目 题目出的还可以。答了1个半小时 然后让你回去等消息 

原题大致是这样 合同表 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
13 楼 shenglongq 2009-03-02  
Create proc query_t1
@param1 int
as
   select avg(t.smoney),t.sprovince from T1 t join T1 t1 on(t.sprovince=t1.sprovince) where t.id=@param1
go


insert into T(smoney,sprovince) execute query_t1
12 楼 shenglongq 2009-03-02  
select * from T1 t1 where t1.smoney>(select   distinct avg(t2.smoney) from T1 t2 join T1 t3 on(t2.sprovince=t3.sprovince) where t2.id=t1.id)
11 楼 a56165993 2009-03-02  
select avg(money),address,money from test group by address having avg(money)>=money;
10 楼 benpaolang 2009-03-02  
9 楼 nwpufw 2009-03-02  
1:
select A.*
from test A
where A.smoney > (select avg(B.smoney)
                  from test B
                  where B.sprovince = B.sprovince)

"第二道:把同一地区的  平均业绩 地区 插入到新表中 (新表只包含两个字段即:平均业绩 地区)"
2.题目中要求是向新表中插入,所以这个表是存在的。不防取名新表名为newsell,字段“平均业绩 地区”为“smoney,sprovince”.
insert into  newsell (smoney,sprovince)
select avg(smoney)avgmoney,sprovince
from sell group by sprovince;
8 楼 cartonwang 2009-03-01  
第一道:显示出  业绩 大于同一地区平均值的 合同id  姓名 地区 业绩
select t2.id,t2.name,t2.province,t2.money, t1.avg_money
       from t_employee t2, (select t.province, avg(t.money)   avg_money
                           from t_employee t
                           group by t.province) t1
       where t2.province = t1.province
       and t2.money > t1.avg_money
      
第二道:把同一地区的  平均业绩 地区 插入到新表中 (新表只包含两个字段即:平均业绩 地区)

      
      
create table t_employee_avg as (select avg(e.money) avg_money, e.province from t_employee e group by e.province);

相关推荐

    经典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