oracle(查询).doc
上传人:sy****28 上传时间:2024-09-15 格式:DOC 页数:4 大小:23KB 金币:16 举报 版权申诉
预览加载中,请您耐心等待几秒...

oracle(查询).doc

oracle(查询).doc

预览

在线预览结束,喜欢就下载吧,查找使用更方便

16 金币

下载此文档

如果您无法下载资料,请参考说明:

1、部分资料下载需要金币,请确保您的账户上有足够的金币

2、已购买过的文档,再次下载不重复扣费

3、资料包下载后请先用软件解压,在使用对应软件打开

oralce之学习!select(查询语句)是oracle中的重中之重在oracle中默认表中有以下几种:emp表,其中该表的字段为:empno(员工编号)ename(员工名称)job(工作种类)mgr(经理人)hiredate(入职日期)sal(工资)comm(津贴)deptno(员工所在的部门编号)dept表,其中该表的字段为:deptno(部门编号)dname(部门名称)loc(部门所在地方)salgrade(工资等级)表,其中该表的字段为:grade(等级)losal(起始范围)hisal(结束范围)select*fromsalgrade;(查询薪水的等级的所有范围)select*fromdept;(查询部门的详细信息)select*fromemp;(查询员工的详细信息)查询所有员工只年薪selectename,sal*12fromemp;任何含有空值的数学表达式最后所得到的结果全部是空值,如计算员工的一年收入:Seleceename,sal*12+commfromemp;所以在计算所以员工的一年的收入为:字符串连接表达式为||Distinct关键字所代表的意思是:去掉所有重复的数据Where关键字A,求部门编号是10的员工?selectename,sal*12fromemp;B,求员工月薪大于3000的员工都又哪些?selectename,sal*12fromemp;C,找出和KING名字相同用户的薪水?selectename,salfromempwhereename='KING'between…and关键字薪水在800到2000之间的员工都有哪些?selectename,salfromempwheresalbetween800and2000;或者是selectename,salfromempwheresal>=800andsal<=2000;空值处理求出津贴是空值的员工?selectename,commfromempwherecommisnull;不是空值的在is后面加上not;(符合英文的习惯)但是不等于selectename,commfromempwherecomm=null;like关键字a,求员工名称中的含有A的所有员工?selectenamefromempwhereenamelike'%A%';b,求员工名称中的第三个字母为A的所有员工?selectenamefromempwhereenamelike'__A%'c,如果员工中名称含有%的员工如何求出?selectenamefromempwhereenamelike'%\%%';d,如果员工中名称含有%的员工如何求出?同时转译字符只能是^来转译?selectenamefromempwhereenamelike'%^%%'escape'^';orderby关键字求员工表中按照工资的降序排序?selectename,deptno,salfromemporderbysaldesc;求员工表中按照部门升序排序后在按照员工薪金进行排序?selectename,deptno,salfromemporderbydeptnoasc,saldesc;练习1,求某人及其经理人的名字?(单表自连接)selecte1.ename,e2.enamefromempe1,empe2wheree1.mgr=e2.empno2,三张表的关联selectename,dname,gradefromempejoindeptdon(e.deptno=d.deptno)joinsalgradeson(e.salbetweens.losalands.hisal)wherelower(ename)like'%a%';3,部门平均薪水的等级selectdeptno,avg_sal,gradefrom(selectdeptno,avg(sal)avg_salfromempgroupbydeptno)tjoinsalgradeson(t.avg_salbetweens.losalands.hisal)4,部门平均的薪水等级(先求每个人的名称,部门编号和薪水等级)selectdeptno,avg(grade)from(selectdeptno,ename,gradefromempjoinsalgradeson(emp.salbetweens.losalands.hisal))tgroupbydeptno5,雇员中有那些人是经理人?(只要雇员编号出现在了里面就是经理人)selectenamefro