-
decode(條件,判斷條件,ture返回,false返回); to_char(parameter,格式)返回新格式內容;查看全部
-
select empno,ename,sal,(select avg(sal) from emp where deptno=e.deptno) avgsal from emp e where sal>(select avg(sal) from emp where deptno=e.deptno);查看全部
-
子查詢的類型 (1)單行子查詢:只返回一條記錄 操作符:=,>,>=,<,<=,<>不等于 例子:查詢員工信息,要求:職位與7566員工一樣,薪水大于7782的 select * from emp where job= (select job from emp where empno=7566) and sal>(select sal from emp where empno=7782); (2)多行子查詢:返回多條記錄 操作符:in 等于列表中的任何一個 any 和子查詢返回的任意一個值作比較 all 和子查詢返回的所有值比較 例子:(1)in 查詢部門名稱是sales 和accounting 的員工信息 select *from emp where deptno in (select deptno from dept where dname='SALES' or dname='ACCOUNTING'); select e.* from emp e, dept d where e.deptno=d.deptno and (d.dname='SALES' or d.dname='ACCOUNTING'); (2)any 查詢工資比30號部門任意一個員工高的員工信息 select * from emp where sal> any ( select sal from emp where deptno=30); select * from emp where sal>(select min(sal) from emp where deptno=30); (3)all 查詢工資比30號部門所有一個員工高的員工信息 select * from emp where sal> all( select sal from emp where deptno=30); select * from emp where sal>(select max(sal) from emp where deptno=30);查看全部
-
ownum是偽列,oracle默認生成行號 行號需要注意的兩個問題 1、行號永遠按照默認的順序生成 2、行號只能使用<,<=;不能使用>,>= select rownum,empno,ename,sal from (select * from emp order by sal desc) where rownum<=3; 將排序后的表作為一個集合放到from()中 生成一個新表 重新再查詢rownum 就可以讓rownum也實現排序了查看全部
-
1.自連接存在的問題:不適合操作大表 解決辦法:層次查詢 層次查詢某些情況下,可以替代自連接 本質上,是一個單表查詢 比如: select empno,ename,sal,mgr from emp connect by prior empno=mgr start with empno=7839; 翻譯過來就是connect by上一層的員工號=老板號 start with empno=根的號 因為根節點并沒有老板,那么我們可以把start with這一句這樣表示 start with mgr is null;就表示他的老板是空值. 2.層次查詢中提供一個偽列:level,來表示樹的深度,我們要想查樹的偽列,必須在select中顯式的寫出來,就像這樣: select level,empno,ename,sal,mgr from emp connect by prior empno=mgr start with mgr=null order by 1; 3.自連接的優缺點:結果直觀,但不適合操作大表 層次查詢的優缺點:是一個單表查詢,不會產生笛卡爾集,但是他得到的結果并沒有自連接那么直觀 需要根據實際問題來選擇用自連接還是層次查詢。查看全部
-
rollup(a,b)===group by a,b;group by a;group by null查看全部
-
where不能使用組函數,當having與where通用時,使用where,效率高查看全部
-
這個當前還沒有用到過,查看全部
-
這里不錯,注意收藏查看全部
-
子查詢用了偽劣rownum,主查詢拿到子查詢返回的結果進行查詢,這時的rownum就不再是子查詢的偽劣了,而是可以作為普通的一列來查詢,所以這時可以使用>符號.查看全部
-
SELECT CI_ID, MAX(TO_CHAR(STU_NAME)) STU_NAME FROM ( SELECT PC.CI_ID CI_ID,WM_CONCAT(PS.STU_NAME) OVER(PARTITION BY PC.CI_ID ORDER BY PS.STU_ID) STU_NAME FROM PM_CI PC,PM_STU PS WHERE INSTR(PC.STU_IDS,PS.STU_ID)>0) GROUP BY CI_ID ORDER BY CI_ID;查看全部
-
什么是分組函數? 分組函數作用于一組數據,并對一組數據返回一個值。查看全部
-
紅色叉叉,,哈哈哈查看全部
-
where后面不能使用組函數查看全部
-
層次查詢有KING 而自查詢沒有查看全部
舉報
0/150
提交
取消