HIVE-几道经典的hive题目
建表相关语句在此,具体的数据自己制作吧
create table student(Sno int,Sname string,Sex string,Sage int,Sdept string)row format delimited fields terminated by ','stored as textfile;
create table course(Cno int,Cname string) row format delimited fields terminated by ',' stored as textfile;
create table sc(Sno int,Cno int,Grade int)row format delimited fields terminated by ',' stored as textfile;
第一题:理解distribute by 分区。sort by 和 order by的区别
1.0 查询学生信息,按性别分区,在分区内按年龄有序
select * from student order by sex, sage; set mapred.reduce.tasks=2;
select * from student distribute by sex sort by sage;
distribute by 是按照指定的字段对数据进行划分到不同的reduce中 第一的语句,我们只是按照性别和年龄排序
第二个,我们设置了2个reduce,并且按照性别分区。sort by sage; 理解sort by和order by的区别。order by是全局排序。而sort by是每个分区内部排序。 95021 周二 男 17 MA
95015 王君 男 18 MA
95005 刘刚 男 18 MA
95011 包小柏 男 18 MA
95004 张立 男 19 IS
95010 孔小涛 男 19 CS
95022 郑明 男 20 MA
95001 李勇 男 20 CS
95016 钱国 男 21 MA
95020 赵钱 男 21 IS
95013 冯伟 男 21 CS
95006 孙庆 男 23 CS
95017 王风娟 女 18 IS
95009 梦圆圆 女 18 MA
95008 李娜 女 18 CS
95014 王小丽 女 19 CS
95018 王一 女 19 IS
95019 邢小丽 女 19 IS
95002 刘晨 女 19 IS
95007 易思玲 女 19 MA
95012 孙花 女 20 CS
95003 王敏 女 22 MA
第二题,理解夺标关联join的使用,注意join的顺序
2.0 查询学生的姓名、课程名称和分数
select student.sname,course.cname,sc.grade
from student
join sc on student.sno = sc.sno
join course on sc.cno = course.cno join后面跟要连接的表,on后面跟连接的条件。
on和where是不同的
-on指的连接条件
-where是表链接后,再进一步按照where指定条件筛选
--------------------------------
李勇 数据库 81
李勇 数学 85
李勇 信息系统 88
李勇 操作系统 70
刘晨 数学 90
刘晨 信息系统 80
刘晨 操作系统 71
刘晨 数据结构 60
王敏 数据库 82
王敏 信息系统 90
王敏 数据结构 100
张立 数据库 80
张立 数学 92
张立 操作系统 91
张立 数据结构 70
刘刚 数据库 70
刘刚 数学 92
刘刚 信息系统 99
刘刚 数据处理 87
孙庆 数据库 72
孙庆 数学 62
孙庆 信息系统 100
孙庆 操作系统 59
孙庆 数据结构 60
孙庆 数据处理 98
易思玲 信息系统 68
易思玲 操作系统 91
易思玲 数据结构 94
易思玲 数据处理 78
李娜 数据库 98
李娜 信息系统 89
李娜 数据处理 91
梦圆圆 数学 81
梦圆圆 操作系统 89
梦圆圆 数据处理 100
第三题,请理解on和where的区别
查询选修2号课程且成绩在90分以上的所有学生的姓名和分数
select student.sname, sc.grade
from student
join sc on student.sno=sc.sno
where sc.cno=2 and sc.grade>90;
on和where是不同的
-on指的连接条件
-where是表链接后,再进一步按照where指定条件筛选
上面语句的执行过程如下 1,执行from从student抽取所有数据
2,执行join和sc按照on condition的条件拼接成一个表。不理解的同学,把到此的语句打出来看看拼接后的样子
3,从2已经拼接后的临时表格中,按照where的sc.cno=2 and sc.grade>90;条件筛选数据
4,从3筛选后的数据中select所需要的字段 学习sql理解上面过程是十分重要的,这其实只是单纯的sql和hive没有太大关联。理解这个过程也就理解了。on和where的区别。
第四题,理解左外连接,其实就是sql语法
查询所有学生的姓名,如果在成绩表中有成绩,则输出成绩表中的课程号
select student.sname, sc.cno
from student
left outer join sc on student.sno = sc.sno;
左向外联接的结果集包括 LEFT OUTER子句中指定的左表的所有行,而不仅仅是联接列所匹配的行。如果左表的某行在右表中没有匹配行,则在相关联的结果集行中右表的所有选择列表列均为空值。
HIVE-几道经典的hive题目的更多相关文章
- 几道经典的SQL笔试题目
几道经典的SQL笔试题目(有答案) (1)表名:购物信息 购物人 商品名称 数量 A 甲 2 B 乙 ...
- 【甘道夫】Hive 0.13.1 on Hadoop2.2.0 + Oracle10g部署详细解释
环境: hadoop2.2.0 hive0.13.1 Ubuntu 14.04 LTS java version "1.7.0_60" Oracle10g ***欢迎转载.请注明来 ...
- C语言100道经典算法
经典的100个c算法 C语言的学习要从基础,100个经典的算法真不知道关于语言的应该发在那里,所以就在这里发了,发贴的原因有2个,第一个,这东西非常值得学习,第二个,想..........嘿嘿,大家应 ...
- 50道经典的JAVA编程题(汇总)
这是一次不可思议的编程历程.从2013年的最后一天开始做这份题,中间连续好几天的考试,包括java考试(今天考试的JAVA编程题),直到今天完成了.挺有成就感的...废话不多说了,来电实质性的吧. 全 ...
- 50道经典的JAVA编程题(46-50)
50道经典的JAVA编程题(46-50),最后五道题了,这是一个美妙的过程,编程真的能让我忘掉一切投入其中,感觉很棒.今天下午考完微机原理了,大三上学期就这样度过了,这学期算是解放了,可是感觉我还是没 ...
- 50道经典的JAVA编程题(41-45)
50道经典的JAVA编程题(41-45),苦逼的程序猿,晚上睡不着了编程吧~今天坚持做10道题!发现编程能是我快乐...O(∩_∩)O哈哈~能平静我烦乱的心,剩下5道题留到考试完了再做吧!该睡觉了.. ...
- 50道经典的JAVA编程题(36-40)
50道经典的JAVA编程题(36-40),今天晚上心情压抑,不爽,继续做题,管它明天考试,我继续我的java,一个周末都在看微机原理看得的很头疼啊~明天该挂科就挂吧,不在乎了~~~ [程序36] Ar ...
- 50道经典的JAVA编程题(31-35)
50道经典的JAVA编程题(31-35),今天考完了java,在前篇博客里面贴出了题了,见:<今天考试的JAVA编程题>.考完了也轻松了,下个星期一还考微机原理呢,啥都不会,估计今天就做到 ...
- 50道经典的JAVA编程题(26-30)
50道经典的JAVA编程题(26-30),这么晚了,早点睡了要,明早8点考java祝我好运吧!!!晚安~ [程序26]Ex26.java(跳过了,好没意思的题啊)题目:请输入星期几的第一个字母来判断一 ...
随机推荐
- qt的登录设置(转)
1.下面添加代码来实现使用用户名和密码登录,这里只是简单将用户名和密码设置为了固定的字符串,如果以后学习了数据库,还可以通过读取数据库来获取用户名和密码.到logindialog.cpp文件中将登录按 ...
- 【leetcode刷题笔记】Word Ladder II
Given two words (start and end), and a dictionary, find all shortest transformation sequence(s) from ...
- 学会Retrofit+OkHttp+RxAndroid三剑客的使用,让自己紧跟Android潮流的步伐
http://blog.csdn.net/iamzgx/article/details/51607387 概括 在上一篇博客android网络框架OkHttp之get请求(源码初识) 讲解了OkHtt ...
- WebSocket 初体验
其实老早就觊觎 Socket 这碗美食了,在 WebSocket 发出后更是心潮澎湃... 奈何这需要后端同志的帮助,使得至今才得以品尝.(当然本文也只涉及前端部分) 以前想监听其他设备变化,大屏幕交 ...
- I.MX6Q(TQIMX6Q/TQE9)学习笔记——U-Boot移植
其实Freescale的BSP移植文档已经将u-boot的移植步骤讲述的非常详细了,但为了以后方便查阅,还是按照自己的理解记录在这里. 获取源码 根据前一篇文章搭建好LTIB环境后就可以非常方便的导出 ...
- Python编程-多态、封装、特性
一.多态与多态性 1.多态 (1)什么是多态 多态指的是一类事物有多种形态,(一个抽象类有多个子类,因而多态的概念依赖于继承) 序列类型有多种形态:字符串,列表,元组. 动物有多种形态:人,狗,猪 文 ...
- @MarkFan 口语练习录音 20140406 [美女与野兽的口语练习录音]
大家好,您现在收听的是美女与野兽的口语练习录音 敢于追求,不惧任何挑战,才是勇敢的人生.试想一下,世界上每天有多少人为了梦想,为了生活,甚至是为了别人在不停地奔跑.假若你此刻心中装有梦想,却碍于现实不 ...
- tcp底层连接过程(c语言)
在用了多种上位机开发环境,包括mfc.Qt.C#之后,发现它们的API都是对底层协议的(可以说是C语言)的封装,所以了解了底层协议,任意换上位机开发环境都是没问题的. 1.服务器创建套接字socket ...
- MongoDB快速入门(七)- Save() 方法
MongoDB Save() 方法 save() 方法取代,通过新文档到 save()方法 语法 mongodb 的 save()方法如下所示的基本语法: >db.COLLECTION_NAME ...
- freopen重定向输入
#include <bits\stdc++.h> using namespace std; int main() { freopen("C:\\Users\\dcf\\Deskt ...