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

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

ORACLE常用傻瓜問題1000問全集(四)
  301. V$BUFFER_POOL     顯示實例緩沖池的信息。   302. V$BUFFER_POOL_STATISTICS     顯示實例緩沖池的信息。   303. V$CACHE     包含當前實例的SGA中的每一個塊的頭部信息。   304. V$CAC...查看完整版>>ORACLE常用傻瓜問題1000問全集(四)
 
ORACLE常用傻瓜問題1000問全集(八)
  701. USER_MVIEWS     數據庫中當前用戶擁有的所有的物化視圖。   702. USER_NESTED_TABLES     當前用戶擁有的表中的嵌套表。   703. USER_OBJ_AUDIT_OPTS     用戶擁有的表和視圖的審計選項。...查看完整版>>ORACLE常用傻瓜問題1000問全集(八)
 
ORACLE常用傻瓜問題1000問全集(十)
  901. CHAINED_ROWS     存儲帶LIST CHAINED ROWS子句的ANALYZE命令的輸出。   902. CHAINGE_SOURCES     答應發行者查看現有的變化資源。   903. CHANGE_SETS     答應發行者查看現有的變化設置...查看完整版>>ORACLE常用傻瓜問題1000問全集(十)
 
ORACLE常用傻瓜問題1000問全集(四)
  301. V$BUFFER_POOL  顯示實例緩沖池的信息。  302. V$BUFFER_POOL_STATISTICS  顯示實例緩沖池的信息。  303. V$CACHE  包含當前實例的SGA中的每一個塊的頭部信息。  304. V$CACHE_LOCK  包含當前...查看完整版>>ORACLE常用傻瓜問題1000問全集(四)
 
ORACLE常用傻瓜問題1000問全集(六)
  501. DBA_COL_PRIVS  列出數據庫中授予列的所有特權。  502. DBA_COLL_TYPES  顯示數據庫中所有命名的集合類型。  503. DBA_CONS_COLUMNS  包含在約束定義中的,可訪問的列的信息。  504. DBA_CONST...查看完整版>>ORACLE常用傻瓜問題1000問全集(六)
 
ORACLE常用傻瓜問題1000問全集(八)
  701. USER_MVIEWS  數據庫中當前用戶擁有的所有的物化視圖。  702. USER_NESTED_TABLES  當前用戶擁有的表中的嵌套表。  703. USER_OBJ_AUDIT_OPTS  用戶擁有的表和視圖的審計選項。  704. USER_OBJ...查看完整版>>ORACLE常用傻瓜問題1000問全集(八)
 
ORACLE常用傻瓜問題1000問全集(十)
  901. CHAINED_ROWS  存儲帶LIST CHAINED ROWS子句的ANALYZE命令的輸出。  902. CHAINGE_SOURCES  允許發行者查看現有的變化資源。  903. CHANGE_SETS  允許發行者查看現有的變化設置。  904. CHANGE...查看完整版>>ORACLE常用傻瓜問題1000問全集(十)
 
ORACLE常用傻瓜問題1000問全集(一)
  1. Oracle安裝完成後的初始口令?     internal/oracle     sys/change_on_install     system/manager     scott/tiger     sysman/oem_temp   2. ORACLE9IAS WEB CACHE的初始默認用戶和密...查看完整版>>ORACLE常用傻瓜問題1000問全集(一)
 
ORACLE常用傻瓜問題1000問全集(三)
  201. /*+NOCACHE(TABLE)*/      當進行全表掃描時,CACHE提示能夠將表的檢索塊放置在緩沖區緩存中最近最少列表LRU的最近使用端      例如:      SELECT /*+FULL(BSEMPMS) NOCAHE(BSEMPMS) */ EMP_N...查看完整版>>ORACLE常用傻瓜問題1000問全集(三)
 
 
回到王朝網路移動版首頁