注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

北漂的小羊

Java编程,开发者,程序员,软件开发,编程,代码。新浪微博号:IT国子监

 
 
 

日志

 
 
关于我

在这里是面向程序员的高品质IT技术学习社区,是程序员学习成长的地方。让我们更好地用技术改变世界。请关注新浪微博号: IT国子监(http://weibo.com/itguozijian)

网易考拉推荐

程序员几道面试题(转自:ITEYE:234390216)  

2013-03-06 17:38:49|  分类: 面试题 |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |

       最近正在换工作,面试了几家公司,做了一些笔试题,现把其中几道还有点意思的题贴出来。在这边文章中我想先把这几道题贴出来,之后再进行解答。

1.如何用一条语句把一张表的数据插入到另一张数据库表中?

 

2.如何用一条语句把一张表的数据插入到另一张不存在的数据库表中?

 

3.有如下A、B两个表,如何将A表的数据查询出来,结果如B所示?

         A表:

姓名

科目

分数

张三

语文

60

李四

数学

65

张三

英语

70

张三

数学

75

李四

语文

80

李四

英语

68

 

         B表:

姓名

语文

数学

英语

总分

张三

 

 

 

 

李四

 

 

 

 

 

4.有如下几个类,我先运行TestA,再运行TestB,那么:

         class A:

Java代码 
  1. public class A {  
  2.     public static int a = 6;  
  3. }  

 

class TestA:

Java代码 
  1. public class TestA {  
  2.     public static void main(String args[]) {  
  3.        A a = new A();  
  4.        a.a++;  
  5.        System.out.println(a.a);  
  6.     }  
  7. }  

 

class TestB:

Java代码 
  1. public class TestB {  
  2.     public static void main(String args[]) {  
  3.        A b = new A();  
  4.        System.out.println(b.a);  
  5.     }  
  6. }  

 

(1)运行TestA的时候输出的结果是什么?

 

(2)运行TestB的时候输出的结果是什么?

 

(3)运行TestA和TestB的结果为什么相同或不相同?

 

 


 解答:

 

1.如何用一条语句把一张表的数据插入到另一张数据库表中?

 

Sql代码 
  1. insert into tableA select * from tableB  

 

2.如何用一条语句把一张表的数据插入到另一张不存在的数据库表中?

 

Sql代码 
  1. select * into tableB from tableA;  
  2. -------或者是下面这种写法  
  3. create table tableB as select * from tableA;  

 

3.有如下A、B两个表,如何将A表的数据查询出来,结果如B所示?

         A表:

姓名

科目

分数

张三

语文

60

李四

数学

65

张三

英语

70

张三

数学

75

李四

语文

80

李四

英语

68

 

         B表:

姓名

语文

数学

英语

总分

张三

 

 

 

 

李四

 

 

 

 

这里我们用一个t_student表来表示A表,其建表语句如下所示:

Sql代码 
  1. create table t_student(name varchar2(4), course varchar2(4), score int);  

那么这个时候要用一条SQL语句把A表的数据查询出B表的结果,我们可以如下定义我们的SQL语句:

Sql代码 
  1. select a.name 姓名,sum(case when course='语文' then score end) 语文,sum(cas  
  2. when course='英语' then score end) 英语,sum(case when course='数学' then score  
  3.  end) 数学,b.total 总分 from t_student a, (select namesum(score) total from t_  
  4. student group by name) b where a.name=b.name group by a.name,b.total order by a.  
  5. name desc;  

 这条语句的总体思路是:

  • 先用分组的形式查询出每个人的总成绩
  • 用case when的形式把课程列分为多列,这样满足的那一列的成绩就是当前人当前课程的成绩,其他的成绩在当前行为空

姓名       语文       数学       英语

---- ---------- ---------- ----------

张三         60

张三                    75

张三                               70

李四                               68

李四         80

李四                    65

 

  • 把上述两个结果按照相同的姓名连接起来并按照姓名和总分分组,这样我们查询出来的结果就可以显示姓名和总分,那么我们没有按照成绩进行分组,那么当我们用分组语句的时候该如何查询出我们的成绩呢?这个时候sum就起作用了,根据之前分析的,每个人每门成绩只有一个有效值,其他的为空,所以我们对它进行汇总的结果还是其当前课程的成绩,这就可以满足我们在分组的情况下查询出对应的成绩。(在进行分组查询的时候,只能查询出对应的分组字段和统计字段)
  • 最后一步进行排序是为了按照“张三”,“李四”那样的顺序排列

 上面查询出来的结果会如下所示:

姓名       语文       英语       数学       总分

------ ------ ------- ------- --------

张三         60         70         75        205

李四         80         68         65        213

 

4.有如下几个类,我先运行TestA,再运行TestB,那么:

         class A:

Java代码 
  1. public class A {  
  2.     public static int a = 6;  
  3. }  

 

class TestA:

Java代码 
  1. public class TestA {  
  2.     public static void main(String args[]) {  
  3.        A a = new A();  
  4.        a.a++;  
  5.        System.out.println(a.a);  
  6.     }  
  7. }  

 

class TestB:

Java代码 
  1. public class TestB {  
  2.     public static void main(String args[]) {  
  3.        A b = new A();  
  4.        System.out.println(b.a);  
  5.     }  
  6. }  

 

(1)运行TestA的时候输出的结果是什么?

 7

(2)运行TestB的时候输出的结果是什么?

 6

(3)运行TestA和TestB的结果为什么相同或不相同?

 虽然变量a是类A的静态变量,但是TestATestB是两个不同的应用程序,TestA中改变的变量a的值不会影响到TestB中的结果。

  评论这张
 
阅读(350)| 评论(0)
推荐 转载

历史上的今天

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2016