Oracle最新的Sql笔试题及答案

| PRODUCT_CODE | NUMBER | N | 产品编码 |

| QUANTITY | NUMBER | N | 产品数量 |

| PRICE | NUMBER | N | 产品单价 |

问题

================================================================

1.编写SQL语句,查询PIM_HEADERS表,符合日期在2011-03-01和2011-03-25之间的PI订单,显示订单号,创建日志,订单客户名称,订单业务员名称

select

t1.PI_NO

,t1.CREATION_DATE

,t2.CUSTOM_NAME

,t3.USER_NAME

from (select

from PIM_HEADERS

where CREATION_DATE between

to_date(‘2011-03-01’,‘yyyy-mm-dd’)

and

to_date(‘2011-03-25’,‘yyyy-mm-dd’)

) t1

left join CTM_CUSTOMERS t2

on t1.CUSTOMER_ID = t2.CUSTOMER_ID

left join SM_USER t3

on t1.OPERATOR_ID = t3.USER_ID

2.编写SQL语句,查询所有部门名称及其给部门的业务员的个数,部门在2011-01-01到2011-03-01之间创建的PI订单数

select t1._DEPARTMENT_NAME,count(t2.USER_NAME),count(t3.PI_NO)

from SM_DEPT t1

left join SM_USER_DEPT t2

on t1.dept_id = t2.dept_id

left join (select

from PIM_HEADERS

where CREATION_DATE between

to_date(‘2011-01-01’,‘yyyy-mm-dd’)

and

to_date(‘2011-03-01’,‘yyyy-mm-dd’)

) t3

on t2.user_id = t3.OPERATOR_ID

group by t1.DEPT_ID

3.编写SQL语句,查询所有客户及其相关PI订单号,PI创建日期,PI订单相关业务员姓名及其业务所属部门名称

select

t1.*

,t2.PI_NO

,t2.CREATION_DATE

,t3.USER_NAME

,t5.DEPARTMENT_NAME

from SM_CUSTOMERS t1

left join PIM_HEADERS t2

on t1.CUSTOER_ID = t2.CUSTOMER_ID

left join SM_USER t3

on t2.OPERATOR_ID = t3.user_id

left join SM_USER_DEPT t4

on t3.USER_ID = t4.USER_ID

left join SM_DEPT t5

on t4.DEPT_ID = t5.DEPT_ID

4.编写SQL语句,更新没有下过PI订单的客户名称的备注为“从未发生业务往来”

update CTM_CUSTOMERS t1 set COMMENTS = ‘从未反生业务往来’

where not exists (

select PI_NO from PIM_HEADERS t2

where t2.CUSTOMER_ID = t1.CUSTOMER_ID

) ;

commit;

5.编写SQL语句,查询所有客户名称及其所属城市,并按照城市名称降序,用户名称升序排序

select CUSTOM_NAME,CITY

from CTM_CUSTOMERS

order by city desc,CUSTOMER_NAME asc

6.编写SQL语句,查询出所有的客户的PI订单的下单金额,显示客户名称,订单币种,订单总数量及订单总额

select

t2.CUSTOMER_NAME

,t1.CURRENCY_CODE

,t3.TOTAL

,t4.TOTAL_MONEY

from PIM_HEADERS t1

left join CTM_CUSTOMERS t2

on t1.CUSTOMER_ID = t2.CUSTOMER_ID

left join (

select PI_ID,sum(QUANTITY) TOTAL,sum(QUANTITY*PRICE) TOTAL_MONEY

from PIM_LINES

group by PI_ID

) t3

on t1.PI_ID = t3.PI_ID;

7.编写函数,函数需传入部门ID,返回结果部门对应所有业务员姓名连接起来,中间用逗号隔开

create or replace function getUserByDeptId

( dept_id number) return varchar2

is

res varchar2(200);

cursor mycursor(did number) is

select t2.CUSTOMER_NAME

from (select *

from SM_USER_DEPT

where dept_id = did

) t1

left join SM_USER t2

on t1.USER_ID = t2.USER_ID ;

begin

for c_row in mycursor(dept_id) loop

res := res ||‘,’|| c_row

end loop;
return res;
end;

最后

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,不论你是刚入门Java开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
65834022)]

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,不论你是刚入门Java开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

  • 18
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值