| 導購 | 订阅 | 在线投稿
分享
 
 
 

ORACLE常用傻瓜問題1000問全集(二)

來源:互聯網  2008-05-31 22:08:16  評論

101. 如何搜索出前N條記錄?

SELECT * FROM empLOYEE WHERE ROWNUM

ORDER BY empno;

102. 如何知道機器上的Oracle支持多少並發用戶數?

SQLconn internal ;

SQLshow parameter processes ;

103. db_block_size可以修改嗎?

一般不可以﹐不建議這樣做的。

104. 如何統計兩個表的記錄總數?

select (select count(id) from aa)+(select count(id) from bb) 總數 from dual;

105. 怎樣用Sql語句實現查找一列中第N大值?

select * from

(select t.*,dense_rank() over (order by sal) rank from employee)

where rank = N;

106. 如何在給現有的日期加上2年?(

select add_months(sysdate,24) from dual;

107. USED_UBLK爲負值表示什麽意思?

It is "harmless"。

108. Connect string是指什麽?

應該是tnsnames.ora中的服務名後面的內容

109. 怎樣擴大REDO LOG的大小?

建立一個臨時的redolog組,然後切換日志,刪除以前的日志,建立新的日志。

110. tablespace 是否不能大于4G?

沒有限制。

111. 返回大于等于N的最小整數值?

SELECT CEIL(N) FROM DUAL;

112. 返回小于等于N的最小整數值?

SELECT FLOOR(N) FROM DUAL;

113. 返回當前月的最後一天?

SELECT LAST_DAY(SYSDATE) FROM DUAL;

114. 如何不同用戶間數據導入?

IMP SYSTEM/MANAGER FILE=AA.DMP FROMUSER=USER_OLD TOUSER=USER_NEW ROWS=Y INDEXES=Y ;

115. 如何找數據庫表的主鍵字段的名稱?

SQLSELECT * FROM user_constraints WHERE CONSTRAINT_TYPE='P' and table_name='TABLE_NAME';

116. 兩個結果集互加的函數?

SQLSELECT * FROM BSEMPMS_OLD INTERSECT SELECT * FROM BSEMPMS_NEW;

SQLSELECT * FROM BSEMPMS_OLD UNION SELECT * FROM BSEMPMS_NEW

SQLSELECT * FROM BSEMPMS_OLD UNION ALL SELECT * FROM BSEMPMS_NEW;

117. 兩個結果集互減的函數?

SQLSELECT * FROM BSEMPMS_OLD MINUS SELECT * FROM BSEMPMS_NEW;

118. 如何配置Sequence?

建sequence seq_custid

create sequence seq_custid start 1 incrememt by 1;

建表時:

create table cust

{ cust_id smallint not null,

...}

insert 時:

insert into table cust

values( seq_cust.nextval,...)

日期的各部分的常用的的寫法

119. 取時間點的年份的寫法:

SELECT TO_CHAR(SYSDATE,'YYYY') FROM DUAL;

120. 取時間點的月份的寫法:

SELECT TO_CHAR(SYSDATE,'MM') FROM DUAL;

121. 取時間點的日的寫法:

SELECT TO_CHAR(SYSDATE,'DD') FROM DUAL;

122. 取時間點的時的寫法:

SELECT TO_CHAR(SYSDATE,'HH24') FROM DUAL;

123. 取時間點的分的寫法:

SELECT TO_CHAR(SYSDATE,'MI') FROM DUAL;

124. 取時間點的秒的寫法:

SELECT TO_CHAR(SYSDATE,'SS') FROM DUAL;

125. 取時間點的日期的寫法:

SELECT TRUNC(SYSDATE) FROM DUAL;

126. 取時間點的時間的寫法:

SELECT TO_CHAR(SYSDATE,'HH24:MI:SS') FROM DUAL;

127. 日期,時間形態變爲字符形態:

SELECT TO_CHAR(SYSDATE) FROM DUAL;

128. 將字符串轉換成日期或時間形態:

SELECT TO_DATE('2003/08/01') FROM DUAL;

129. 返回參數的星期幾的寫法:

SELECT TO_CHAR(SYSDATE,'D') FROM DUAL;

130. 返回參數一年中的第幾天的寫法:

SELECT TO_CHAR(SYSDATE,'DDD') FROM DUAL;

131. 返回午夜和參數中指定的時間值之間的秒數的寫法:

SELECT TO_CHAR(SYSDATE,'SSSSS') FROM DUAL;

132. 返回參數中一年的第幾周的寫法:

SELECT TO_CHAR(SYSDATE,'WW') FROM DUAL;

虛擬字段

133. CURRVAL 和 nextval

爲表創建序列

CREATE SEQUENCE EMPSEQ ... ;

SELECT empseq.currval FROM DUAL ;

自動插入序列的數值

INSERT INTO emp

VALUES (empseq.nextval, 'LEWIS', 'CLERK',

7902, SYSDATE, 1200, NULL, 20) ;

134. ROWNUM

按設定排序的行的序號

SELECT * FROM emp WHERE ROWNUM

135. ROWID

返回行的物理地址

SELECT ROWID, ename FROM emp WHERE deptno = 20 ;

136. 將N秒轉換爲時分秒格式?

set serverout on

declare

N number := 1000000;

ret varchar2(100);

begin

ret := trunc(n/3600) '小時' to_char(to_date(mod(n,3600),'sssss'),'fmmi"分 "ss"秒"') ;

dbms_output.put_line(ret);

end;

137. 如何查詢做比較大的排序的進程?

SELECT b.tablespace, b.segfile#, b.segblk#, b.blocks, a.sid, a.serial#, a.username, a.osuser, a.status

FROM v$session a,v$sort_usage b

WHERE a.saddr = b.session_addr

ORDER BY b.tablespace, b.segfile#, b.segblk#, b.blocks ;

138. 如何查詢做比較大的排序的進程的SQL語句?

select /*+ ORDERED */ sql_text from v$sqltext a

where a.hash_value = (

select sql_hash_value from v$session b

where b.sid = &sid and b.serial# = &serial)

order by piece asc ;

139. 如何查找重複記錄?

SELECT * FROM TABLE_NAME

WHERE ROWID!=(SELECT MAX(ROWID) FROM TABLE_NAME D

WHERE TABLE_NAME.COL1=D.COL1 AND TABLE_NAME.COL2=D.COL2);

140. 如何刪除重複記錄?

DELETE FROM TABLE_NAME

WHERE ROWID!=(SELECT MAX(ROWID) FROM TABLE_NAME D

WHERE TABLE_NAME.COL1=D.COL1 AND TABLE_NAME.COL2=D.COL2);

141. 如何快速編譯所有視圖?

SQL SPOOL VIEW1.SQL

SQL SELECT 『ALTER VIEW 『TNAME』

COMPILE;』 FROM TAB;

SQL SPOOL OFF

然後執行VIEW1.SQL即可。

SQL @VIEW1.SQL;

142. ORA-01555 SNAPSHOT TOO OLD的解決辦法

增加MINEXTENTS的值,增加區的大小,設置一個高的OPTIMAL值。

143. 事務要求的回滾段空間不夠,表現爲表空間用滿(ORA-01560錯誤),回滾段擴展到達參數 MAXEXTENTS的值(ORA-01628)的解決辦法。

向回滾段表空間添加文件或使已有的文件變大;增加MAXEXTENTS的值。

144. 如何加密ORACLE的存儲過程?

下列存儲過程內容放在AA.SQL文件中

create or replace procedure testCCB(i in number) as

begin

dbms_output.put_line('輸入參數是'to_char(i));

end;

SQLwrap iname=a.sql;

PL/SQL Wrapper: Release 8.1.7.0.0 - ProdUCtion on Tue Nov 27 22:26:48 2001

Copyright (c) Oracle Corporation 1993, 2000. All Rights Reserved。

Processing AA.sql to AA.plb

運行AA.plb

SQL @AA.plb ;

145. 如何監控事例的等待?

select event,sum(decode(wait_Time,0,0,1)) "Prev",

sum(decode(wait_Time,0,1,0)) "Curr",count(*) "Tot"

from v$session_Wait

group by event order by 4;

146. 如何回滾段的爭用情況?

select name, waits, gets, waits/gets "Ratio"

from v$rollstat C, v$rollname D

where C.usn = D.usn;

147. 如何監控表空間的 I/O 比例?

select B.tablespace_name name, B.file_name "file", A.phyrds pyr, A.phyblkrd pbr, A.phywrts pyw, A.phyblkwrt pbw

from v$filestat A, dba_data_files B

where A.file# = B.file_id

order by B.tablespace_name;

148. 如何監控文件系統的 I/O 比例?

select substr(C.file#,1,2) "#", substr(C.name,1,30) "Name", C.status, C.bytes, D.phyrds, D.phywrts

from v$datafile C, v$filestat D

where C.file# = D.file#;

149. 如何在某個用戶下找所有的索引?

select user_indexes.table_name, user_indexes.index_name,uniqueness, column_name

from user_ind_columns, user_indexes

where user_ind_columns.index_name = user_indexes.index_name

and user_ind_columns.table_name = user_indexes.table_name

order by user_indexes.table_type, user_indexe

  101. 如何搜索出前N條記錄?   SELECT * FROM empLOYEE WHERE ROWNUM   ORDER BY empno;   102. 如何知道機器上的Oracle支持多少並發用戶數?     SQLconn internal ;   SQLshow parameter processes ;   103. db_block_size可以修改嗎?     一般不可以﹐不建議這樣做的。   104. 如何統計兩個表的記錄總數?     select (select count(id) from aa)+(select count(id) from bb) 總數 from dual;   105. 怎樣用Sql語句實現查找一列中第N大值?     select * from   (select t.*,dense_rank() over (order by sal) rank from employee)   where rank = N;   106. 如何在給現有的日期加上2年?(     select add_months(sysdate,24) from dual;   107. USED_UBLK爲負值表示什麽意思?     It is "harmless"。   108. Connect string是指什麽?       應該是tnsnames.ora中的服務名後面的內容   109. 怎樣擴大REDO LOG的大小?       建立一個臨時的redolog組,然後切換日志,刪除以前的日志,建立新的日志。   110. tablespace 是否不能大于4G?     沒有限制。   111. 返回大于等于N的最小整數值?     SELECT CEIL(N) FROM DUAL;   112. 返回小于等于N的最小整數值?     SELECT FLOOR(N) FROM DUAL;   113. 返回當前月的最後一天?     SELECT LAST_DAY(SYSDATE) FROM DUAL;   114. 如何不同用戶間數據導入?     IMP SYSTEM/MANAGER FILE=AA.DMP FROMUSER=USER_OLD TOUSER=USER_NEW ROWS=Y INDEXES=Y ;   115. 如何找數據庫表的主鍵字段的名稱?     SQLSELECT * FROM user_constraints WHERE CONSTRAINT_TYPE='P' and table_name='TABLE_NAME';   116. 兩個結果集互加的函數?     SQLSELECT * FROM BSEMPMS_OLD INTERSECT SELECT * FROM BSEMPMS_NEW;   SQLSELECT * FROM BSEMPMS_OLD UNION SELECT * FROM BSEMPMS_NEW   SQLSELECT * FROM BSEMPMS_OLD UNION ALL SELECT * FROM BSEMPMS_NEW;   117. 兩個結果集互減的函數?   SQLSELECT * FROM BSEMPMS_OLD MINUS SELECT * FROM BSEMPMS_NEW;   118. 如何配置Sequence?     建sequence seq_custid     create sequence seq_custid start 1 incrememt by 1;     建表時:     create table cust     { cust_id smallint not null,     ...}     insert 時:     insert into table cust     values( seq_cust.nextval,...)   日期的各部分的常用的的寫法   119. 取時間點的年份的寫法:      SELECT TO_CHAR(SYSDATE,'YYYY') FROM DUAL;   120. 取時間點的月份的寫法:      SELECT TO_CHAR(SYSDATE,'MM') FROM DUAL;   121. 取時間點的日的寫法:      SELECT TO_CHAR(SYSDATE,'DD') FROM DUAL;   122. 取時間點的時的寫法:      SELECT TO_CHAR(SYSDATE,'HH24') FROM DUAL;   123. 取時間點的分的寫法:      SELECT TO_CHAR(SYSDATE,'MI') FROM DUAL;   124. 取時間點的秒的寫法:      SELECT TO_CHAR(SYSDATE,'SS') FROM DUAL;   125. 取時間點的日期的寫法:      SELECT TRUNC(SYSDATE) FROM DUAL;   126. 取時間點的時間的寫法:      SELECT TO_CHAR(SYSDATE,'HH24:MI:SS') FROM DUAL;   127. 日期,時間形態變爲字符形態:      SELECT TO_CHAR(SYSDATE) FROM DUAL;   128. 將字符串轉換成日期或時間形態:      SELECT TO_DATE('2003/08/01') FROM DUAL;   129. 返回參數的星期幾的寫法:      SELECT TO_CHAR(SYSDATE,'D') FROM DUAL;   130. 返回參數一年中的第幾天的寫法:      SELECT TO_CHAR(SYSDATE,'DDD') FROM DUAL;   131. 返回午夜和參數中指定的時間值之間的秒數的寫法:      SELECT TO_CHAR(SYSDATE,'SSSSS') FROM DUAL;   132. 返回參數中一年的第幾周的寫法:      SELECT TO_CHAR(SYSDATE,'WW') FROM DUAL;   虛擬字段   133. CURRVAL 和 nextval     爲表創建序列     CREATE SEQUENCE EMPSEQ ... ;     SELECT empseq.currval FROM DUAL ;     自動插入序列的數值     INSERT INTO emp       VALUES (empseq.nextval, 'LEWIS', 'CLERK',           7902, SYSDATE, 1200, NULL, 20) ;   134. ROWNUM     按設定排序的行的序號     SELECT * FROM emp WHERE ROWNUM   135. ROWID     返回行的物理地址     SELECT ROWID, ename FROM emp WHERE deptno = 20 ;   136. 將N秒轉換爲時分秒格式?     set serverout on     declare      N number := 1000000;      ret varchar2(100);     begin      ret := trunc(n/3600) '小時' to_char(to_date(mod(n,3600),'sssss'),'fmmi"分 "ss"秒"') ;      dbms_output.put_line(ret);     end;   137. 如何查詢做比較大的排序的進程?     SELECT b.tablespace, b.segfile#, b.segblk#, b.blocks, a.sid, a.serial#, a.username, a.osuser, a.status     FROM v$session a,v$sort_usage b     WHERE a.saddr = b.session_addr     ORDER BY b.tablespace, b.segfile#, b.segblk#, b.blocks ;   138. 如何查詢做比較大的排序的進程的SQL語句?     select /*+ ORDERED */ sql_text from v$sqltext a     where a.hash_value = (      select sql_hash_value from v$session b      where b.sid = &sid and b.serial# = &serial)     order by piece asc ;   139. 如何查找重複記錄?     SELECT * FROM TABLE_NAME     WHERE ROWID!=(SELECT MAX(ROWID) FROM TABLE_NAME D      WHERE TABLE_NAME.COL1=D.COL1 AND TABLE_NAME.COL2=D.COL2);   140. 如何刪除重複記錄?     DELETE FROM TABLE_NAME     WHERE ROWID!=(SELECT MAX(ROWID) FROM TABLE_NAME D     WHERE TABLE_NAME.COL1=D.COL1 AND TABLE_NAME.COL2=D.COL2);   141. 如何快速編譯所有視圖?     SQL SPOOL VIEW1.SQL     SQL SELECT 『ALTER VIEW 『TNAME』     COMPILE;』 FROM TAB;     SQL SPOOL OFF     然後執行VIEW1.SQL即可。     SQL @VIEW1.SQL;   142. ORA-01555 SNAPSHOT TOO OLD的解決辦法     增加MINEXTENTS的值,增加區的大小,設置一個高的OPTIMAL值。   143. 事務要求的回滾段空間不夠,表現爲表空間用滿(ORA-01560錯誤),回滾段擴展到達參數 MAXEXTENTS的值(ORA-01628)的解決辦法。     向回滾段表空間添加文件或使已有的文件變大;增加MAXEXTENTS的值。   144. 如何加密ORACLE的存儲過程?     下列存儲過程內容放在AA.SQL文件中     create or replace procedure testCCB(i in number) as     begin      dbms_output.put_line('輸入參數是'to_char(i));     end;     SQLwrap iname=a.sql;     PL/SQL Wrapper: Release 8.1.7.0.0 - ProdUCtion on Tue Nov 27 22:26:48 2001     Copyright (c) Oracle Corporation 1993, 2000. All Rights Reserved。     Processing AA.sql to AA.plb     運行AA.plb     SQL @AA.plb ;   145. 如何監控事例的等待?     select event,sum(decode(wait_Time,0,0,1)) "Prev",     sum(decode(wait_Time,0,1,0)) "Curr",count(*) "Tot"     from v$session_Wait     group by event order by 4;   146. 如何回滾段的爭用情況?     select name, waits, gets, waits/gets "Ratio"     from v$rollstat C, v$rollname D     where C.usn = D.usn;   147. 如何監控表空間的 I/O 比例?     select B.tablespace_name name, B.file_name "file", A.phyrds pyr, A.phyblkrd pbr, A.phywrts pyw, A.phyblkwrt pbw     from v$filestat A, dba_data_files B     where A.file# = B.file_id     order by B.tablespace_name;   148. 如何監控文件系統的 I/O 比例?     select substr(C.file#,1,2) "#", substr(C.name,1,30) "Name", C.status, C.bytes, D.phyrds, D.phywrts     from v$datafile C, v$filestat D     where C.file# = D.file#;   149. 如何在某個用戶下找所有的索引?     select user_indexes.table_name, user_indexes.index_name,uniqueness, column_name     from user_ind_columns, user_indexes     where user_ind_columns.index_name = user_indexes.index_name      and user_ind_columns.table_name = user_indexes.table_name     order by user_indexes.table_type, user_indexe
󰈣󰈤
王朝萬家燈火計劃
期待原創作者加盟
 
 
 
>>返回首頁<<
 
 
 
 
 熱帖排行
 
 
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有