日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

ORACLE SQL*PLUS 命令大全

發(fā)布時(shí)間:2024/7/23 数据库 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 ORACLE SQL*PLUS 命令大全 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

來源:http://www.cnblogs.com/kerrycode/archive/2011/06/09/2076248.html




---1:?HELP?INDEX
HELP?命令查詢相關(guān)命令的信息。

你可以從下面看到大概有54個(gè)SQL
*PLUS命令。每個(gè)命令都有大量的參數(shù)選項(xiàng),你不可能清楚的記得每個(gè)命令
以及它相關(guān)的參數(shù)細(xì)節(jié),所以當(dāng)你遺忘時(shí),就可以用HELP命令來查看相關(guān)命令的命令信息

SQL
>?HELP?INDEX

Enter?Help?
[topic]?for?help.

?@?????????????COPY?????????PAUSE????????????????????
SHUTDOWN
?@@????????????DEFINE???????
PRINT????????????????????SPOOL
?
/?????????????DEL??????????PROMPT???????????????????SQLPLUS
?ACCEPT????????DESCRIBE?????QUIT?????????????????????START
?APPEND????????DISCONNECT???RECOVER??????????????????STARTUP
?ARCHIVE?
LOG???EDIT?????????REMARK???????????????????STORE
?ATTRIBUTE?????
EXECUTE??????REPFOOTER????????????????TIMING
?
BREAK?????????EXIT?????????REPHEADER????????????????TTITLE
?BTITLE????????GET??????????RESERVED?WORDS?(SQL)?????UNDEFINE
?CHANGE????????HELP?????????RESERVED?WORDS?(PL
/SQL)??VARIABLE
?CLEAR?????????HOST?????????RUN??????????????????????WHENEVER?OSERROR
?
COLUMN????????INPUT????????SAVE?????????????????????WHENEVER?SQLERROR
?
COMPUTE???????LIST?????????SET
?CONNECT???????PASSWORD?????SHOW
?
?HELP?
[TOPIC]?來查看相關(guān)命令介紹以及語法。?可以用?代替HELP
?
?例子:
?HELP?DESCRIBE
?
???COPY
?


---2:?@
?運(yùn)行調(diào)入內(nèi)存的sql文件(文件可以是本機(jī)腳本文件或web服務(wù)器上的腳本文件)
?
@跟START命令具有相同功能??梢杂肧TART替代。可以不指定該文件擴(kuò)展名
?
?
?@?("at"?
sign)
?
-------------
?Runs?the?SQL*Plus?statements?in?the?specified?script.?The?script?can?be
?called?
from?the?local?file?system?or?a?web?server.?Only?the?url?form?is
?supported?
in?iSQL*Plus.

?@?{url
|file_name[.ext]}?[arg?...]

?
where?url?supports?HTTP?and?FTP?protocols?in?the?form:

????http:
//host.domain/script.sql


例子:執(zhí)行test。sql腳本文件
?
?SQL
>?@?F:/test.sql
?
?其中test.sql中腳本如下所示
?
??PROMPT
??PROMPT?
'顯示5條員工信息'
??PROMPT
??
??
SELECT?*?FROM?SCOTT.EMP?WHERE?ROWNUM?<=?5
??
/
??
??運(yùn)行結(jié)果如圖所示。
?
?
---3?@@
?@@?運(yùn)行調(diào)入內(nèi)存的sql文件,跟@命令很相像。如果運(yùn)行的腳本文件中有嵌入腳本,則@@比較有用。
?
?@@?(
double?"at"?sign)
?
---------------------

?Runs?the?specified?script.?This?command?
is?almost?identical?to
?the?@?command.?It?
is?useful?for?running?nested?scripts?because?it
?has?the?additional?functionality?
of?looking?for?the?nested?script
?
in?the?same?url?or?path?as?the?calling?script.?Only?the?url?form
?
is?supported?in?iSQL*Plus.

?@@?{url
|file_name[.ext]}?[arg?...]
?


---4??/?
執(zhí)行當(dāng)前緩沖區(qū)的命令(運(yùn)行上一次執(zhí)行的SQL語句).

SQL
>?HELP?/

?
/?(slash)
?
---------

?Executes?the?most?recently?executed?SQL?command?
or?PL/SQL?block
?which?
is?stored?in?the?SQL?buffer.?Use?slash?(/)?at?the?command
?prompt?
or?line?number?prompt?in?SQL*Plus?command?line,?or?use
?slash?(
/)?in?the?iSQL*Plus?Workspace.?The?buffer?has?no?command
?history?
and?does?not?record?SQL*Plus?commands.
?
?
?例子:如下圖所示:
?
---5??ACCEPT

?SQL
>?HELP??ACCEPT?

?ACCEPT可以修改既有變量,也可定義一個(gè)新變量并等待用戶輸入初始值。


?ACCEPT
?
------

?Reads?a?line?
of?input?and?stores?it?in?a?given?substitution?variable.
?
In?iSQL*Plus,?displays?the?Input?Required?screen?for?you?to?enter?a
?value?
for?the?substitution?variable.

?ACC
[EPT]?variable?[NUM[BER]?|?CHAR?|?DATE?|?BINARY_FLOAT?|?BINARY_DOUBLE]
?
[FOR[MAT]?format]?[DEF[AULT]?default]?[PROMPT?text?|?NOPR[OMPT]]?[HIDE]

---6?APPEND
?????將text附加到當(dāng)前行之后。

SQL
>?HELP?APPEND

?APPEND
?
------

?Adds?
text?to?the?end?of?the?current?line?in?the?SQL?buffer.

?A
[PPEND]?text

?
Not?available?in?iSQL*Plus
?
?
---7??ARCHIVE?LOG?
??????啟動(dòng)或停止歸檔在線重做日志文件。

SQL
>?HELP?ARCHIVE?LOG
?????
?ARCHIVE?
LOG
?
-----------

?Starts?
or?stops?automatic?archiving?of?online?redo?log?files,
?manually?(explicitly)?archives?specified?redo?
log?files,?or
?displays?information?about?redo?
log?files.

?ARCHIVE?
LOG?{LIST|STOP}?|?{START|NEXT|ALL|integer}?[TO?destination]
?


---8??ATTRIBUTE

SQL
>?HELP?ATTRIBUTE

?ATTRIBUTE
?
---------

?Specifies?display?characteristics?
for?a?given?attribute?of?an?Object?Type
?
column,?such?as?the?format?of?NUMBER?data.?Columns?and?attributes?should
?
not?have?the?same?names?as?they?share?a?common?namespace.?Lists?the
?
current?display?characteristics?for?a?single?attribute?or?all?attributes.

?ATTRIBUTE?
[type_name.attribute_name?[option?...?]]

?
where?option?represents?one?of?the?following?terms?or?clauses:
?????ALI
[AS]?alias
?????CLE
[AR]
?????
FOR[MAT]?format
?????
LIKE?{type_name.attribute_name?|?alias}
?????
ON|OFF

---9??BREAK
?? ??break命令抑制重復(fù)的列或表達(dá)你的名字的默認(rèn)值。因此,要制止重復(fù)在ORDER BY子句中指定的列值,使用最簡單的形式break命令:
SQL
>?HELP??BREAK

?
BREAK
?
-----

?Specifies?
where?changes?occur?in?a?report?and?the?formatting
?action?
to?perform,?such?as:
?
-?suppressing?display?of?duplicate?values?for?a?given?column
?
-?skipping?a?line?each?time?a?given?column?value?changes
???(
In?iSQL*Plus,?only?when?Preformatted?Output?is?ON)
?
-?printing?computed?figures?each?time?a?given?column?value
???changes?
or?at?the?end?of?the?report.
?Enter?
BREAK?with?no?clauses?to?list?the?current?BREAK?definition.

?BRE
[AK]?[ON?report_element?[action?[action]]]?...

?
where?report_element?has?the?following?syntax:
?????{
column?|?expression?|?ROW?|?REPORT}

?
and?where?action?has?the?following?syntax:
?????
[SKI[P]?n?|?[SKI[P]]?PAGE]?[NODUP[LICATES]?|?DUP[LICATES]]

?The?SKIP?
option?is?not?supported?in?iSQL*Plus


---10??BTITLE
??設(shè)置格式化頁腳
??
SQL
>?HELP??BTITLE?;

?BTITLE
?
------

?Places?
and?formats?a?specified?title?at?the?bottom?of?each?report
?page,?
or?lists?the?current?BTITLE?definition.

?BTI
[TLE]?[printspec?[text|variable]?...]?|?[OFF|ON]

?
where?printspec?represents?one?or?more?of?the?following?clauses:

?????COL?n??????????LE
[FT]????????BOLD
?????S
[KIP]?[n]?????CE[NTER]??????FORMAT?text

?? ? TAB?n??????????R[IGHT]?

???


---11?CHANGE
??????將SQL*Plus緩沖區(qū)當(dāng)前行的old_value替換為new_value;

?Changes?the?first?occurrence?
of?the?specified?text?on?the?current
?line?
of?the?SQL?buffer.?The?buffer?has?no?command?history?list?and
?does?
not?record?SQL*Plus?commands.

?C
[HANGE]?sepchar?old?[sepchar?[new[sepchar]]]

?
Not?available?in?iSQL*Plus


---12?CLEAR
??????清除或重設(shè)當(dāng)前指定配置的值。CLEAR?BUFFER?即清空緩存區(qū)所有行。

Resets?
or?erases?the?current?value?or?setting?for?the?specified?option.

CL
[EAR]?option?...

where?option?represents?one?of?the?following?clauses:
????BRE
[AKS]
????BUFF
[ER]
????COL
[UMNS]
????COMP
[UTES]
????SCR
[EEN]
????SQL
????TIMI
[NG]

CLEAR?SCREEN?
is?not?available?in?iSQL*Plus

例子:
???CLEAR?BUFFER;
??
???CLEAR?SQL;


---13??COLUMN
???????用于格式化列標(biāo)題和列數(shù)據(jù)的現(xiàn)實(shí)格式。

?Specifies?display?attributes?
for?a?given?column,?such?as:
?????
-?text?for?the?column?heading
?????
-?alignment?for?the?column?heading
?????
-?format?for?NUMBER?data
?????
-?wrapping?of?column?data
?Also?lists?the?
current?display?attributes?for?a?single?column
?
or?all?columns.

?COL
[UMN]?[{column?|?expr}?[option?...]?]

?
where?option?represents?one?of?the?following?clauses:
?????ALI
[AS]?alias
?????CLE
[AR]
?????ENTMAP?{
ON|OFF}
?????FOLD_A
[FTER]
?????FOLD_B
[EFORE]
?????
FOR[MAT]?format
?????HEA
[DING]?text
?????JUS
[TIFY]?{L[EFT]?|?C[ENTER]?|?R[IGHT]}
?????
LIKE?{expr?|?alias}
?????NEWL
[INE]
?????NEW_V
[ALUE]?variable
?????NOPRI
[NT]?|?PRI[NT]
?????NUL
[L]?text
?????OLD_V
[ALUE]?variable
?????
ON|OFF
?????WRA
[PPED]?|?WOR[D_WRAPPED]?|?TRU[NCATED]
?????
例子:
??????
?
---14?COMPUTE

In?combination?with?the?BREAK?command,?calculates?and?prints
summary?lines?using?various?standard?computations.?Also?lists
all?COMPUTE?definitions.

COMP
[UTE]?[function?[LAB[EL]?text]?...
??
OF?{expr|column|alias}?...
??
ON?{expr|column|alias|REPORT|ROW}?...]


---15?CONNECT
??????連接數(shù)據(jù)數(shù)據(jù)庫命令.如果是SYSDBA或SYSOPER賬號(hào),則必須在后面加上AS?{SYSOPER?|?SYSDBA},否則會(huì)報(bào)錯(cuò)。

CONNECT
-------

Connects?a?given?username?
to?the?Oracle?Database.?When?you?run?a
CONNECT?command,?the?site?profile,?glogin.sql,?
and?the?user?profile,
login.sql,?are?processed?
in?that?order.?CONNECT?does?not?reprompt
for?username?or?password?if?the?initial?connection?does?not?succeed.

CONN
[ECT]?[{logon|/|proxy}?[AS?{SYSOPER|SYSDBA}]]

where?logon?has?the?following?syntax:
????username
[/password][@connect_identifier]

例子:

SQL
>CONNECT?SYSDBA/U*jd24))(&^??AS?SYSDBA;
?
SQL
>CONN?SYSTEM/KERRY123456
已連接。
SQL
>?HELP?CONN
?
?
---16?COPY
?? ??COPY可以完成遠(yuǎn)程數(shù)據(jù)庫、本地?cái)?shù)據(jù)庫或ORACLE數(shù)據(jù)庫與非ORACLE 數(shù)據(jù)庫之間的數(shù)據(jù)復(fù)制

Copies?data?
from?a?query?to?a?table?in?the?same?or?another
database.?COPY?supports?CHAR,?DATE,?LONG,?NUMBER?and?VARCHAR2.

COPY?{
FROM?database?|?TO?database?|?FROM?database?TO?database}
???????????{APPEND
|CREATE|INSERT|REPLACE}?destination_table
???????????
[(column,?column,?column,?...)]?USING?query

where?database?has?the?following?syntax:
????username
[/password]@connect_identifier
????

---17???DEFINE
?定義替換變量并附值給它,或列出指定賦值變量值或所有變量
?Specifies?a?substitution?variable?
and?assigns?a?CHAR?value?to?it,?or
?lists?the?value?
and?variable?type?of?a?single?variable?or?all?variables.

?DEF
[INE]?[variable]?|?[variable?=?text]
?
?例子:
SQL
>?DEFINE
DEFINE?_DATE???????????
=?"09-6月?-11"?(CHAR)
DEFINE?_CONNECT_IDENTIFIER?
=?"orcl"?(CHAR)
DEFINE?_
USER???????????=?"SYSTEM"?(CHAR)
DEFINE?_PRIVILEGE??????
=?""?(CHAR)
DEFINE?_SQLPLUS_RELEASE?
=?"1002000100"?(CHAR)
DEFINE?_EDITOR?????????
=?"Notepad"?(CHAR)
DEFINE?_O_VERSION??????
=?"Oracle?Database?10g?Enterprise?Edition?Release?10.2.0.1.0?-?
With?the?Partitioning,?OLAP?and?Data?Mining?options"?(CHAR)
DEFINE?_O_RELEASE??????
=?"1002000100"?(CHAR)
DEFINE?_RC?????????????
=?"1"?(CHAR)

SQL
>?DEFINE?_EDITOR
DEFINE?_EDITOR?????????
=?"Notepad"?(CHAR)

---18???DEL
???????DEL刪除命令緩沖區(qū)的某一行。?DEL?刪除當(dāng)前行??DEL?n?刪除第n行。
?Deletes?one?
or?more?lines?of?the?SQL?buffer.?The?buffer?has?no
?command?history?list?
and?does?not?record?SQL*Plus?commands.

?DEL?
[n?|?n?m?|?n?*?|?n?LAST?|?*?|?*?n?|?*?LAST?|?LAST]

?
Not?available?in?iSQL*Plus
?
?例子:
?
?DEL?
1;

---19???DESCRIBE
?返回?cái)?shù)據(jù)庫所存儲(chǔ)對(duì)象的描述。這個(gè)命令大家用得相當(dāng)多,比如查看表的數(shù)據(jù)字典等,在此不細(xì)說。

?Lists?the?
column?definitions?for?a?table,?view,?or?synonym
?
or?the?specifications?for?a?function?or?procedure.

?
DESC[RIBE]?{[schema.]object[@connect_identifier]}
?
?
?例子:
?
DESC?SCOTT.EMP;
?


SQL
>??DESC?SCOTT.EMP;
?名稱??????????????????????????????????????是否為空??類型
?
-----------------------------------------?--------?-----------------------
?EMPNO??????????????????????????????????????????????NOT?NULL?NUMBER(4)
?ENAME??????????????????????????????????????????????
VARCHAR2(10)
?JOB????????????????????????????????????????????????
VARCHAR2(9)
?MGR????????????????????????????????????????????????
NUMBER(4)
?HIREDATE???????????????????????????????????????????DATE
?SAL????????????????????????????????????????????????
NUMBER(7,2)
?COMM???????????????????????????????????????????????
NUMBER(7,2)
?DEPTNO?????????????????????????????????????????????
NUMBER(2)


---20??DISCONNECT
?讓當(dāng)前用戶從ORACLE數(shù)據(jù)庫斷開,但是不退出?SQL*PLUS

?Commits?pending?changes?
to?the?database?and?logs?the?current
?
user?out?of?Oracle,?but?does?not?exit?SQL*Plus.
?
In?SQL*Plus?command?line,?use?EXIT?or?QUIT?to?log?out?of?Oracle
?
and?return?control?to?your?computer''s?operating?system.
?
In?iSQL*Plus,?click?the?Logout?button?to?log?out?of?Oracle.

?DISC
[ONNECT]
?
?例子
?SQL
>?DISCONNECT;
?從?Oracle?
Database?10g?Enterprise?Edition?Release?10.2.0.1.0?-?Production
?
With?the?Partitioning,?OLAP?and?Data?Mining?options?斷開
?
?如果想退出SQL
*PLUS程序,可以用EXIT或QUIT
---21??EDIT
?調(diào)用操作系統(tǒng)文本編輯器打開指定文件或編輯緩沖區(qū)的內(nèi)容。如果不指定文件名,例如??EDIT?F:/,則會(huì)提示您創(chuàng)建新的文件。
?文本編輯器在Windows下是Notepad,?在Unix或Linux下是Vi或emacs,可以用DEFINE?_EDITOR?
=?‘編輯器名字’改變默認(rèn)編輯器
?
?Invokes?an?operating?system?
text?editor?on?the?contents?of?the
?specified?
file?or?on?the?contents?of?the?SQL?buffer.?The?buffer
?has?no?command?history?list?
and?does?not?record?SQL*Plus?commands.

?ED
[IT]?[file_name[.ext]]

?
Not?available?in?iSQL*Plus
?
?例子:不指定文件名
?SQL
>?EDIT?F:/
?
?會(huì)創(chuàng)建一個(gè)
*。sql文件,如下圖所示

?SQL
>?EDIT?F:/123.TXT?創(chuàng)建123.txt文件。如下圖所示?
?

---22??EXECUTE
??執(zhí)行存儲(chǔ)過程或PL/SQL塊

?Executes?a?
single?PL/SQL?statement?or?runs?a?stored?procedure.

?
EXEC[UTE]?statement

---23??EXIT
?退出SQL*PLUS

?Commits?
or?rolls?back?all?pending?changes,?logs?out?of?Oracle,
?terminates?SQL
*Plus?and?returns?control?to?the?operating?system.
?
In?iSQL*Plus,?commits?or?rolls?back?all?pending?changes,?stops
?processing?the?
current?iSQL*Plus?script?and?returns?focus?to?the
?Workspace.?There?
is?no?way?to?access?the?return?code?in?iSQL*Plus.
?
In?iSQL*Plus?click?the?Logout?button?to?log?out?of?Oracle?Database.

?{
EXIT|QUIT}?[SUCCESS|FAILURE|WARNING|n|variable|:BindVariable]
???
[COMMIT|ROLLBACK]

?
---24???GET
????????將SQL文件的內(nèi)容讀入SQL*Plus緩沖區(qū)。查看保存的腳本

?Loads?a?SQL?statement?
or?PL/SQL?block?from?a?script?into?the?SQL?buffer.
?
In?iSQL*Plus?click?the?Load?Script?button?to?load?a?script?into?the
?Workspace.?The?buffer?has?no?command?history?list?
and?does?not?record
?SQL
*Plus?commands.

?GET?
[FILE]?file_name[.ext]?[LIST?|?NOLIST]

?
Not?available?in?iSQL*Plus

例子:SQL
>?GET?FILE?F:/11.EXT?LIST
??
1??1111111
??
2*?111111
??
??其中1,2所列內(nèi)容是我放在11.EXT中的內(nèi)容
?
?

?
---25?HOST

?HOST
?
----

?Executes?an?operating?system?command?without?leaving?SQL
*Plus.
?Enter?HOST?without?command?
to?display?an?operating?system?prompt.
?You?can?
then?enter?multiple?operating?system?commands.

?HO
[ST]?[command]

?
Not?available?in?iSQL*Plus


---26?INPUT

?INPUT
?
-----

?Adds?one?
or?more?new?lines?of?text?after?the?current?line?in?the
?SQL?buffer.?The?buffer?has?no?command?history?list?
and?does?not
?record?SQL
*Plus?commands.

?I
[NPUT]?[text]

?
Not?available?in?iSQL*Plus


---27?LIST
??????列出SQL*Plus緩存區(qū)的所有行或指定的N行語句。例如?LIST?N;
?LIST
?
----

?Lists?one?
or?more?lines?of?the?most?recently?executed?SQL?command
?
or?PL/SQL?block?which?is?stored?in?the?SQL?buffer.?Enter?LIST?with
?no?clauses?
to?list?all?lines.?In?SQL*Plus?command-line?you?can?also
?
use?";"?to?list?all?the?lines?in?the?SQL?buffer.?The?buffer?has?no
?command?history?list?
and?does?not?record?SQL*Plus?commands.

?L
[IST]?[n?|?n?m?|?n??*?|?n?LAST?|?*?|?*?n?|?*?LAST?|?LAST]

?例子:
??????SQL
>?LIST
??????
1*?SELECT?*?FROM?SCOTT.EMP

---28?PASSWORD;
????更改數(shù)據(jù)庫用戶密碼,不指定用戶,則默認(rèn)跟改SYS用戶賬號(hào)

?PASSWORD
?
--------

?Allows?you?
to?change?a?password?without?displaying?it?on?an?input?device.
?
In?iSQL*Plus,?use?the?Password?screen?to?change?your?password.

?PASSW
[ORD]?[username]

?
Not?available?in?iSQL*Plus

?例子:
???????SQL
>?PASSWORD?
更改?SYS?的口令
舊口令:?
******
新口令:
******
?
?
?
---29?PAUSE;

?PAUSE
?
-----

?Displays?the?specified?
text?then?waits?for?the?user?to?press?RETURN.
?
In?iSQL*Plus,?displays?the?Next?Page?button?which?the?user?must?click
?
to?continue.

?PAU
[SE]?[text]


---30?PRINT;
??????顯示當(dāng)前綁定變量值或列出所有綁定變量

?
PRINT
?
-----

?Displays?the?
current?values?of?bind?variables,?or?lists?all?bind
?variables.

?PRI
[NT]?[variable?...]

---31?PROMPT;
??????使用PROMPT命令可以在屏幕上輸出一行數(shù)據(jù)。這種方式有助于在腳本文件中向用戶
??????傳遞相應(yīng)信息。比如我一個(gè)腳本文件Test.sql里面有下面這一段腳本:
??????PROMPT
??????PROMPT?
'顯示5條員工信息'
??????PROMPT
??????
??????
SELECT?*?FROM?SCOTT.EMP?WHERE?ROWNUM?<?5;
??????
??????
??????
?PROMPT
?
------

?Sends?the?specified?message?
or?a?blank?line?to?the?users?screen.

?PRO
[MPT]?[text]

?例子:
?SQL
>?PROMPT?HELLO?KERRY
?HELLO?KERRY
?
?
---32?QUIT;
??????提交或回滾所有的變化,退出ORACLE,中斷SQL*PLUS。
?QUIT?(Identical?
to?EXIT)
?
----

?Commits?
or?rolls?back?all?pending?changes,?logs?out?of?Oracle,
?terminates?SQL
*Plus?and?returns?control?to?the?operating?system.
?
In?iSQL*Plus,?commits?or?rolls?back?all?pending?changes,?stops
?processing?the?
current?iSQL*Plus?script?and?returns?focus?to?the
?Workspace.?There?
is?no?way?to?access?the?return?code?in?iSQL*Plus.
?
In?iSQL*Plus?click?the?Logout?button?to?log?out?of?Oracle?Database.

?{QUIT
|EXIT}?[SUCCESS|FAILURE|WARNING|n|variable|:BindVariable]
???
[COMMIT|ROLLBACK]


---33?RECOVER;

?RECOVER
?
-------

?Performs?media?recovery?
on?one?or?more?tablespaces,?one?or?more
?datafiles,?
or?the?entire?database.

?Because?
of?possible?network?timeouts,?it?is?recommended?that?you
?
use?SQL*Plus?command-line,?not?iSQL*Plus,?for?long?running?DBA
?operations?such?
as?RECOVER.

?RECOVER?{general?
|?managed}?|?BEGIN?BACKUP?|?END?BACKUP}

?
---34?REMARK

?REMARK
?
------

?Begins?a?comment?
in?a?script.?SQL*Plus?does?not?interpret?the?comment
?
as?a?command.

?REM
[ARK]


---35??REPFOOTER;

?REPFOOTER
?
---------

?Places?
and?formats?a?footer?at?the?bottom?of?a?report,?or?lists?the
?REPFOOTER?definition.

?REPF
[OOTER]?[PAGE]?[printspec?[text|variable]?...]?|?[OFF|ON]

?
where?printspec?represents?one?or?more?of?the?following?clauses:
?????COL?n??????????LE
[FT]????????BOLD
?????S
[KIP]?[n]?????CE[NTER]??????FORMAT?text
?????TAB?n??????????R
[IGHT]


---36??REPFOOTER;

?REPFOOTER
?
---------

?Places?
and?formats?a?footer?at?the?bottom?of?a?report,?or?lists?the
?REPFOOTER?definition.

?REPF
[OOTER]?[PAGE]?[printspec?[text|variable]?...]?|?[OFF|ON]

?
where?printspec?represents?one?or?more?of?the?following?clauses:
?????COL?n??????????LE
[FT]????????BOLD
?????S
[KIP]?[n]?????CE[NTER]??????FORMAT?text
?????TAB?n??????????R
[IGHT]

--37?HELP?RESERVED?WORDS?(SQL);
?????查看SQL中保留關(guān)鍵字。有時(shí)候在寫腳本時(shí)應(yīng)該避免使用SQL保留關(guān)鍵字做變量、表名、字段名等
?????如果你不確認(rèn)自己定義的變量是否是保留關(guān)鍵字,就可以用這個(gè)命令看看。如果你只想查看SQL的保留
?????關(guān)鍵字?可以用??HELP?RESERVED?WORDS?(SQL),如果想查看兩者就直接輸入HELP?RESERVED?WORDS?即可。
?
?RESERVED?WORDS?(SQL)
?
-----------------------

?PL
/SQL?Reserved?Words?have?special?meaning?in?PL/SQL,?and?may?not?be?used
?
for?identifier?names?(unless?enclosed?in?"quotes").
?
?
?
---38?HELP?RESERVED?WORDS?(PL/SQL);
??????查看PL/SQL中保留關(guān)鍵字。類似上面命令。

?
?RESERVED?WORDS?(SQL)
--------------------

SQL?Reserved?Words?have?special?meaning?
in?SQL,?and?may?not?be?used?for
identifier?names?unless?enclosed?
in?"quotes".

An?asterisk?(
*)?indicates?words?are?also?ANSI?Reserved?Words.

Oracle?prefixes?implicitly?generated?
schema?object?and?subobject?names
with?"SYS_".?To?avoid?name?resolution?conflict,?Oracle?discourages?you
from?prefixing?your?schema?object?and?subobject?names?with?"SYS_".
?
?
---39?RUN
??????運(yùn)行緩存區(qū)中保存的語句。
?RUN
?
---

?Lists?
and?executes?the?most?recently?executed?SQL?command?or
?PL
/SQL?block?which?is?stored?in?the?SQL?buffer.?The?buffer?has
?no?command?history?list?
and?does?not?record?SQL*Plus?commands.

?R
[UN]


---40?SAVE;
??????將SQL*Plus緩沖區(qū)的內(nèi)容保存到所指定的文件中。如果用戶沒有指定文件擴(kuò)展名,則默認(rèn)
??????擴(kuò)展名為SQL,后面的CREATE表示如果文件不存在創(chuàng)建一個(gè)文件。REPLACE表示如果文件不
??????存在則創(chuàng)建,否則替換覆蓋文件中的內(nèi)容。?APPEND把緩沖區(qū)的內(nèi)容追加到文件末尾。
?
SAVE
?
----

?Saves?the?contents?
of?the?SQL?buffer?in?a?script.?In?iSQL*Plus,?click
?the?
Save?Script?button?to?save?the?Workspace?contents?to?a?script.?The
?buffer?has?no?command?history?list?
and?does?not?record?SQL*Plus?commands.

?SAV
[E]?[FILE]?file_name[.ext]?[CRE[ATE]?|?REP[LACE]?|?APP[END]]

?
Not?available?in?iSQL*Plus

?例子:
???????SQL
>?save?F:/ttt.sql?
---41?SET
?設(shè)置系統(tǒng)變量以及SQL*PLUS環(huán)境變量
?
----------------------------------------SET?命令選項(xiàng)--------------------------------------
?---SET?TIME??{ON?|?OFF}?
?控制當(dāng)前時(shí)間的顯示。取值為ON時(shí),表示在每個(gè)命令提示符前顯示當(dāng)前系統(tǒng)時(shí)間;取值為OFF時(shí)不顯示當(dāng)前的系統(tǒng)時(shí)間。
?
?
---SET?PAUSE?{OFF|?ON?|?TEXT}
??設(shè)置SQL*Plus輸出結(jié)果時(shí)是否滾動(dòng)顯示。
?????????當(dāng)取值為NO時(shí)表示輸出結(jié)果每一頁都暫停,用戶按回車鍵后繼續(xù)顯示;?按CTRL?
+?C退出每一頁顯示。
?????????當(dāng)取值為OFF時(shí)表示一次性全部輸出?
?????????當(dāng)取值為字符串時(shí),每次暫停都顯示該字符串
?????????
?????????
?????
SET?PAUSE?ON;
?????
SET?PAUSE?'按回車鍵繼續(xù)'
?????
SELECT?*?FROM?EMP;
?????
?
---SET?PAGESIZE?{14?|?N};
?設(shè)置每頁打印的行數(shù),該值包括NEWPAGE?設(shè)置的空行數(shù)
??
??
?
---SET?NEWPAGE?{1|?N?|?NONE}??
?設(shè)置每頁打印標(biāo)題前的空行數(shù),默認(rèn)值為1
??
?
---SET?LINESIZE
?設(shè)置每行打印字符數(shù),默認(rèn)每行打印80個(gè)字符??梢栽O(shè)置LINESIZE,以避免折疊顯示。
??
?
---SET?NUMFORMAT
?
?格式掩碼
?
?字符??????????????示例??????????????????????說明
?
9?????????????????999???????????????????????查詢結(jié)果中數(shù)字替換格式中的掩碼
?
0?????????????????999.00????????????????????格式中的掩碼屏蔽掉查詢結(jié)果中的數(shù)字。
?$?????????????????$
999??????????????????????在查詢結(jié)果中的數(shù)字添加美元前綴。
?S?????????????????S999??????????????????????為數(shù)字顯示符號(hào)類型,通常用于顯示查詢結(jié)果中的正負(fù)數(shù)字
?PR????????????????999PR?????????????????????在尖括號(hào)中顯示數(shù)字。
?D?
OR?.????????????99D99.99??????????????????在字符D或字符小數(shù)點(diǎn)"."位置上放置小數(shù)點(diǎn)
?,?????????????????
999,99????????????????????在字符","位置上放置逗號(hào)
?RN?
OR?rn??????????RN????????????????????????根據(jù)字符的大小寫形式,以大寫或者小寫的形式顯示羅馬數(shù)字。
?
?
?
---SET?TIMING?{?ON?|?OFF?}
?顯示SQL命令消耗的系統(tǒng)時(shí)間。
?
?
---42?SHOW
??????顯示SQL*Plus系統(tǒng)變量值或當(dāng)前SQL*Plus的環(huán)境,

?SHOW
?
----

?Shows?the?value?
of?a?SQL*Plus?system?variable,?or?the?current
?SQL
*Plus?environment.?SHOW?SGA?requires?a?DBA?privileged?login.

?SHO
[W]?option
?
?例子:
?
?SQL
>?SHOW?SGA;

Total?System?Global?Area??
612368384?bytes
Fixed?Size??????????????????
1250428?bytes
Variable?Size?????????????
272632708?bytes
Database?Buffers??????????331350016?bytes
Redo?Buffers????????????????
7135232?bytes
?????
?

---43?SHUTDOWN
???關(guān)閉數(shù)據(jù)庫實(shí)例,使用SHUTDOWN時(shí)有5個(gè)參數(shù)可以選擇。

?
SHUTDOWN
?
--------

?Shuts?down?a?currently?running?Oracle?
Database?instance,?optionally
?closing?
and?dismounting?a?database.

?
SHUTDOWN?[ABORT|IMMEDIATE|NORMAL|TRANSACTIONAL?[LOCAL]]
?
?
SHUTDOWN?ABORT???????????????強(qiáng)制關(guān)閉,可能會(huì)丟失部分?jǐn)?shù)據(jù)。如果數(shù)據(jù)庫重啟實(shí)例并打開數(shù)據(jù)庫時(shí),后臺(tái)進(jìn)程SMON會(huì)執(zhí)行恢復(fù)操作
?
?以終止方式關(guān)閉時(shí),?ORACLE將執(zhí)行以下操作
??
1:阻止任何用戶建立新的連接。同時(shí)阻止當(dāng)前連接的用戶開始新的事務(wù)。
??
2:立即終止當(dāng)前正在執(zhí)行的SQL語句。
??
3:任何未提交的事務(wù)均不被回退。
??
4:立即斷開所有用戶的連接,關(guān)閉、卸載數(shù)據(jù)庫,并終止實(shí)例。
?
?
SHUTDOWN?NORMAL??????????????正常關(guān)閉方式
?
?以正常方式關(guān)閉時(shí),ORACLE將執(zhí)行以下操作
??
1:阻止任何用戶建立新的連接
??
2:等待當(dāng)前所有正在連接的用戶主動(dòng)斷開連接,已經(jīng)連接的用戶能夠繼續(xù)當(dāng)前的操作
??
3:一旦所有的用戶都斷開連接,即立即關(guān)閉、卸載數(shù)據(jù)庫,并終止實(shí)例。
??
?
SHUTDOWN?IMMEDIATE???????????立即關(guān)閉方式
?以立即關(guān)閉方式時(shí),ORACLE將執(zhí)行以下操作
?
1:阻止任何用戶建立新的連接。同時(shí)阻止當(dāng)前連接的用戶開始任何新的事務(wù)。
?
2:任何未提交的事務(wù)均被回退。
?
3:ORACLE不再等待用戶主動(dòng)斷開連接,而是直接關(guān)閉、卸載數(shù)據(jù)庫,并終止實(shí)例。
?
?
SHUTDOWN?TRANSACTIONAL???????事務(wù)關(guān)閉方式介于正常關(guān)閉方式與立即關(guān)閉方式之間。它能夠在盡可能短的時(shí)間內(nèi)
??????????????????????????????關(guān)閉數(shù)據(jù)庫,但是能夠保證當(dāng)前所有活動(dòng)事務(wù)都可以被提交。
?以事務(wù)關(guān)閉方式時(shí),ORACLE將執(zhí)行以下操作
?
1:阻止任何用戶建立新的連接,同時(shí)阻止當(dāng)前連接的用戶開始任何新的事務(wù)。
?
2;等待所有未提交的活動(dòng)事務(wù)提交完畢,然后立即斷開用戶連接。
?
3:關(guān)閉、卸載數(shù)據(jù)庫,并終止實(shí)例。???????????????????????????????????????????????????????????????????????????????????????????????????????????????????
?????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????
?
?
---44?SPOOL;
???????將SQL*Plus中輸出的結(jié)果復(fù)制到filename所指定的文件中。
???????
?SPOOL
?
-----

?Stores?query?results?
in?a?file,?or?optionally?sends?the?file?to?a?printer.
?
In?iSQL*Plus,?use?the?Preferences?screen?to?direct?output?to?a?file.

?SPO
[OL]?[file_name[.ext]?[CRE[ATE]?|?REP[LACE]?|?APP[END]]?|?OFF?|?OUT]

?
Not?available?in?iSQL*Plus
?
?例子:
?SQL
>?SPOOL?F:/TEMP.TEXT;
?SQL
>?SELECT?*?FROM?SCOTT.EMP;
?SQL
>?SPOOL?OFF;

?
?
---45??SQLPLUS
????????運(yùn)行SQL*Plus
?SQLPLUS
?
-------

?Starts?SQL
*Plus?from?the?operating?system?prompt.

?SQLPLUS?
[?[option]?[logon]?[start]?]

?
where?option?has?the?following?syntax:
?????
-H[ELP]
?????
|?-V[ERSION]
?????
|?[[-C[OMPATIBILITY]?x.y[.z]]?[-L[OGON]]
????????
[-M[ARKUP]?markup_option]?[-R[ESTRICT]?{1|2|3}]?[-S[ILENT]]]

?
and?where?markup_option?has?the?following?syntax:
?????HTML?
[ON|OFF]?[HEAD?text]?[BODY?text]?[TABLE?text]
??????????
[ENTMAP?{ON|OFF}]?[SPOOL?{ON|OFF}]?[PRE[FORMAT]?{ON|OFF}]

?
and?where?logon?has?the?following?syntax:
?????{username
[/password][@connect_identifier]?|?/}
?????
[AS?{SYSOPER|SYSDBA}]?|?/NOLOG

?
and?where?start?has?the?following?syntax:
?????@{url
|filename[.ext]}?[arg?...]
?????
---46??START
???????將filename文件的內(nèi)容讀入SQL*Plus緩沖區(qū),然后執(zhí)行緩沖區(qū)的腳本(運(yùn)行腳本文件)
?START
?
-----

?Runs?the?SQL
*Plus?statements?in?the?specified?script.?The?script?can?be
?called?
from?the?local?file?system?or?a?web?server.?Only?the?url?form?is
?supported?
in?iSQL*Plus.

?STA
[RT]?{url|file_name[.ext]}?[arg?...]

?
where?url?supports?HTTP?and?FTP?protocols?in?the?form:

????http:
//host.domain/script.sql


---47?STARTUP
??????啟動(dòng)ORACLE實(shí)例。

?STARTUP
-------

Starts?an?Oracle?instance?
with?several?options,?including?mounting,
and?opening?a?database.

STARTUP?options?
|?upgrade_options

where?options?has?the?following?syntax:
???
[FORCE]?[RESTRICT]?[PFILE=filename]?[QUIET]?[?MOUNT?[dbname]?|
???
[?OPEN?[open_options]?[dbname]?]?|
???NOMOUNT?]

where?open_options?has?the?following?syntax:
???
READ?{ONLY?|?WRITE?[RECOVER]}?|?RECOVER

and?where?upgrade_options?has?the?following?syntax:
???
[PFILE=filename]?{UPGRADE?|?DOWNGRADE}?[QUIET]

---?48?STORE

?STORE
?
-----

?Saves?attributes?
of?the?current?SQL*Plus?environment?in?a?script.

?STORE?{
SET}?file_name[.ext]?[CRE[ATE]?|?REP[LACE]?|?APP[END]]

?
Not?available?in?iSQL*Plus
?
---?49?TIMING

?TIMING
?
------

?Records?timing?data?
for?an?elapsed?time?period,?lists?the?current
?timer
''s?name?and?timing?data,?or?lists?the?number?of?active?timers.

?TIMI
[NG]?[START?text|SHOW|STOP]

---50??TTITLE;
???設(shè)置頁眉選項(xiàng)。
?TTITLE
?
------

?Places?
and?formats?a?title?at?the?top?of?each?report?page.
?Enter?TTITLE?
with?no?clause?to?list?its?current?definition.

?The?old?form?
of?TTITLE?is?used?if?only?a?single?word?or
?a?string?
in?quotes?follows?the?TTITLE?command.

?TTI
[TLE]?[printspec?[text|variable]?...]?|?[OFF|ON]

?
where?printspec?represents?one?or?more?of?the?following?clauses:

?????COL?n??????????LE
[FT]????????BOLD
?????S
[KIP]?[n]?????CE[NTER]??????FORMAT?text
?????TAB?n??????????R
[IGHT]
?????
?例子:
??????TTITLE?
ON?????開啟頁眉
??????TTITLE?
OFF????關(guān)閉頁眉
??????
??????SQL
>?TTITLE?CENTER?'職工信息表'
??????SQL
>?SELECT?*?FROM?SCOTT.EMP;

?

---51?UNDEFINE;
????刪除一個(gè)或多個(gè)你定義的替換變量。
?UNDEFINE
?
--------

?Deletes?one?
or?more?substitution?variables?that?you?defined?either
?explicitly?(
with?the?DEFINE?command),?or?implicitly?(with?a?START
?command?argument).

?UNDEF
[INE]?variable?...

---52?VARIABLE;

?VARIABLE
?
--------

?Declares?a?bind?variable?that?can?be?referenced?
in?PL/SQL,?or
?lists?the?
current?display?characteristics?for?a?single?variable
?
or?all?variables.

VAR[IABLE]?[variable?[type]]

?
where?type?represents?one?of?the?following:

?????
NUMBER?????????CHAR??????????CHAR?(n?[CHAR|BYTE])
?????
NCHAR??????????NCHAR?(n)?????VARCHAR2?(n?[CHAR|BYTE])
?????NVARCHAR2?(n)??CLOB??????????NCLOB
?????REFCURSOR??????BINARY_FLOAT??BINARY_DOUBLE
?????
---53?SQL>?WHENEVER?OSERROR

?WHENEVER?OSERROR
?
----------------

?Performs?the?specified?action?(exits?SQL
*Plus?by?default)?if?an
?operating?system?error?occurs?(such?
as?a?file?writing?error).
?
In?iSQL*Plus,?performs?the?specified?action?(stops?the?current
?script?
by?default)?and?returns?focus?to?the?Workspace?if?an
?operating?system?error?occurs.

?WHENEVER?OSERROR?{
EXIT?[SUCCESS|FAILURE|n|variable|:BindVariable]
???????????????????
[COMMIT|ROLLBACK]?|?CONTINUE?[COMMIT|ROLLBACK|NONE]}

???????????????????
---54?
?WHENEVER?SQLERROR
?
-----------------

?Performs?the?specified?action?(exits?SQL
*Plus?by?default)?if?a
?SQL?command?
or?PL/SQL?block?generates?an?error.
?
In?iSQL*Plus,?performs?the?specified?action?(stops?the?current
?script?
by?default)?and?returns?focus?to?the?Workspace?if?a?SQL
?command?
or?PL/SQL?block?generates?an?error.

?WHENEVER?SQLERROR?{
EXIT?[SUCCESS|FAILURE|WARNING|n|variable|:BindVariable]
????????????????????
[COMMIT|ROLLBACK]?|?CONTINUE?[COMMIT|ROLLBACK|NONE]}



一、ORACLE的啟動(dòng)和關(guān)閉
1、在單機(jī)環(huán)境下要想啟動(dòng)或關(guān)閉ORACLE系統(tǒng)必須首先切換到ORACLE用戶,如下
su - oracle a、啟動(dòng)ORACLE系統(tǒng)
oracle>svrmgrl
SVRMGR>connect internal
SVRMGR>startup
SVRMGR>quit b、關(guān)閉ORACLE系統(tǒng)
oracle>svrmgrl
SVRMGR>connect internal
SVRMGR>shutdown
SVRMGR>quit 啟動(dòng)oracle9i數(shù)據(jù)庫命令:
$ sqlplus /nolog
SQL*Plus: Release 9.2.0.1.0 - Production on Fri Oct 31 13:53:53 2003
Copyright (c) 1982, 2002, Oracle Corporation. All rights reserved. SQL> connect / as sysdba
Connected to an idle instance.
SQL> startup^C SQL> startup
ORACLE instance started. 2、在雙機(jī)環(huán)境下要想啟動(dòng)或關(guān)閉ORACLE系統(tǒng)必須首先切換到root用戶,如下
su - root a、啟動(dòng)ORACLE系統(tǒng)
hareg -y oracle b、關(guān)閉ORACLE系統(tǒng)
hareg -n oracle Oracle數(shù)據(jù)庫有哪幾種啟動(dòng)方式 說明: 有以下幾種啟動(dòng)方式:
1、startup nomount
非安裝啟動(dòng),這種方式啟動(dòng)下可執(zhí)行:重建控制文件、重建數(shù)據(jù)庫
讀取init.ora文件,啟動(dòng)instance,即啟動(dòng)SGA和后臺(tái)進(jìn)程,這種啟動(dòng)只需要init.ora文件。 2、startup mount dbname
安裝啟動(dòng),這種方式啟動(dòng)下可執(zhí)行:
數(shù)據(jù)庫日志歸檔、
數(shù)據(jù)庫介質(zhì)恢復(fù)、
使數(shù)據(jù)文件聯(lián)機(jī)或脫機(jī),
重新定位數(shù)據(jù)文件、重做日志文件。 執(zhí)行“nomount”,然后打開控制文件,確認(rèn)數(shù)據(jù)文件和聯(lián)機(jī)日志文件的位置,
但此時(shí)不對(duì)數(shù)據(jù)文件和日志文件進(jìn)行校驗(yàn)檢查。 3、startup open dbname
先執(zhí)行“nomount”,然后執(zhí)行“mount”,再打開包括Redo log文件在內(nèi)的所有數(shù)據(jù)庫文件,
這種方式下可訪問數(shù)據(jù)庫中的數(shù)據(jù)。 4、startup,等于以下三個(gè)命令
startup nomount
alter database mount
alter database open 5、startup restrict
約束方式啟動(dòng)
這種方式能夠啟動(dòng)數(shù)據(jù)庫,但只允許具有一定特權(quán)的用戶訪問
非特權(quán)用戶訪問時(shí),會(huì)出現(xiàn)以下提示:
ERROR:
ORA-01035: ORACLE 只允許具有 RESTRICTED SESSION 權(quán)限的用戶使用 6、startup force
強(qiáng)制啟動(dòng)方式 bitsCN.com中國網(wǎng)管聯(lián)盟
當(dāng)不能關(guān)閉數(shù)據(jù)庫時(shí),可以用startup force來完成數(shù)據(jù)庫的關(guān)閉
先關(guān)閉數(shù)據(jù)庫,再執(zhí)行正常啟動(dòng)數(shù)據(jù)庫命令 7、startup pfile=參數(shù)文件名
帶初始化參數(shù)文件的啟動(dòng)方式
先讀取參數(shù)文件,再按參數(shù)文件中的設(shè)置啟動(dòng)數(shù)據(jù)庫
例:startup pfile=E:Oracleadminoradbpfileinit.ora 8、startup EXCLUSIVE
二、用戶如何有效地利用數(shù)據(jù)字典
 ORACLE的數(shù)據(jù)字典是數(shù)據(jù)庫的重要組成部分之一,它隨著數(shù)據(jù)庫的產(chǎn)生而產(chǎn)生, 隨著數(shù)據(jù)庫的變化而變化,體現(xiàn)為sys用戶下的一些表和視圖。數(shù)據(jù)字典名稱是大寫的英文字符。
??? 數(shù)據(jù)字典里存有用戶信息、用戶的權(quán)限信息、所有數(shù)據(jù)對(duì)象信息、表的約束條件、統(tǒng)計(jì)分析數(shù)據(jù)庫的視圖等。
  我們不能手工修改數(shù)據(jù)字典里的信息。
  很多時(shí)候,一般的ORACLE用戶不知道如何有效地利用它。 dictionary   全部數(shù)據(jù)字典表的名稱和解釋,它有一個(gè)同義詞dict
??? dict_column   全部數(shù)據(jù)字典表里字段名稱和解釋 如果我們想查詢跟索引有關(guān)的數(shù)據(jù)字典時(shí),可以用下面這條SQL語句: SQL>select * from dictionary where instr(comments,'index')>0; 如果我們想知道user_indexes表各字段名稱的詳細(xì)含義,可以用下面這條SQL語句: SQL>select column_name,comments from dict_columns where
table_name='USER_INDEXES'; 依此類推,就可以輕松知道數(shù)據(jù)字典的詳細(xì)名稱和解釋,不用查看ORACLE的其它文檔資料了。 下面按類別列出一些ORACLE用戶常用數(shù)據(jù)字典的查詢使用方法。 1、用戶
??????? 查看當(dāng)前用戶的缺省表空間
??????? SQL>select username,default_tablespace from user_users; 查看當(dāng)前用戶的角色
??????? SQL>select * from user_role_privs; 查看當(dāng)前用戶的系統(tǒng)權(quán)限和表級(jí)權(quán)限
??????? SQL>select * from user_sys_privs;
??????? SQL>select * from user_tab_privs; 2、表
??????????? 查看用戶下所有的表
??????????? SQL>select * from user_tables; 查看名稱包含log字符的表
??????????? SQL>select object_name,object_id from user_objects
??????????????? where instr(object_name,'LOG')>0; 查看某表的創(chuàng)建時(shí)間
??????????? SQL>select object_name,created from user_objects where
object_name=upper('&table_name'); 查看某表的大小
??????????? SQL>select sum(bytes)/(1024*1024) as "size(M)" from
user_segments where segment_name=upper('&table_name'); 查看放在ORACLE的內(nèi)存區(qū)里的表
??????????? SQL>select table_name,cache from user_tables where
instr(cache,'Y')>0; 3、索引
??????????? 查看索引個(gè)數(shù)和類別
??????????? SQL>select index_name,index_type,table_name from
user_indexes order by table_name; 查看索引被索引的字段
??????????? SQL>select * from user_ind_columns where
index_name=upper('&index_name'); 查看索引的大小
??????????? SQL>select sum(bytes)/(1024*1024) as "size(M)" from
user_segments
??????????????? where segment_name=upper('&index_name'); 4、序列號(hào)
??????????? 查看序列號(hào),last_number是當(dāng)前值
??????????? SQL>select * from user_sequences; 5、視圖
??????????? 查看視圖的名稱
??????????? SQL>select view_name from user_views; 查看創(chuàng)建視圖的select語句
??????????? SQL>set view_name,text_length from user_views;
??????????? SQL>set long 2000;???????????????
說明:可以根據(jù)視圖的text_length值設(shè)定set long 的大小
??????????? SQL>select text from user_views where
view_name=upper('&view_name'); 6、同義詞
??????????? 查看同義詞的名稱
??????????? SQL>select * from user_synonyms; 7、約束條件
??????????? 查看某表的約束條件
??????????? SQL>select constraint_name,
constraint_type,search_condition, r_constraint_name
??????????????? from user_constraints where table_name =
upper('&table_name'); SQL>select c.constraint_name,c.constraint_type,cc.column_name
??????????? from user_constraints c,user_cons_columns cc
play.bitsCN.com累了嗎玩一下吧
??????????? where c.owner = upper('&table_owner') and c.table_name =
upper('&table_name')
??????????? and c.owner = cc.owner and c.constraint_name =
cc.constraint_name
??????????? order by cc.position; 8、存儲(chǔ)函數(shù)和過程
??????????? 查看函數(shù)和過程的狀態(tài)
??????????? SQL>select object_name,status from user_objects where
object_type='FUNCTION';
??????????? SQL>select object_name,status from user_objects where
object_type='PROCEDURE'; 查看函數(shù)和過程的源代碼
??????????? SQL>select text from all_source where owner=user and
name=upper('&plsql_name'); 三、查看數(shù)據(jù)庫的SQL
1、查看表空間的名稱及大小
??? select t.tablespace_name, round(sum(bytes/(1024*1024)),0) ts_size
??? from dba_tablespaces t, dba_data_files d
??? where t.tablespace_name = d.tablespace_name
??? group by t.tablespace_name; 2、查看表空間物理文件的名稱及大小
??? select tablespace_name, file_id, file_name,
??? round(bytes/(1024*1024),0) total_space
??? from dba_data_files
??? order by tablespace_name; 3、查看回滾段名稱及大小
??? select segment_name, tablespace_name, r.status,
??? (initial_extent/1024) InitialExtent,(next_extent/1024)
NextExtent,
??? max_extents, v.curext CurExtent
??? From dba_rollback_segs r, v$rollstat v
??? Where r.segment_id = v.usn(+)
??? order by segment_name ; 4、查看控制文件
??? select name from v$controlfile; 5、查看日志文件
??? select member from v$logfile; 6、查看表空間的使用情況
??? select sum(bytes)/(1024*1024) as free_space,tablespace_name
??? from dba_free_space
??? group by tablespace_name; SELECT A.TABLESPACE_NAME,A.BYTES TOTAL,B.BYTES USED, C.BYTES
FREE,
??? (B.BYTES*100)/A.BYTES "% USED",(C.BYTES*100)/A.BYTES "% FREE"
??? FROM SYS.SM$TS_AVAIL A,SYS.SM$TS_USED B,SYS.SM$TS_FREE C
??? WHERE A.TABLESPACE_NAME=B.TABLESPACE_NAME AND
A.TABLESPACE_NAME=C.TABLESPACE_NAME; 7、查看數(shù)據(jù)庫庫對(duì)象
??? select owner, object_type, status, count(*) count# from
all_objects group by owner, object_type, status; 8、查看數(shù)據(jù)庫的版本
??? Select version FROM Product_component_version
??? Where SUBSTR(PRODUCT,1,6)='Oracle'; 9、查看數(shù)據(jù)庫的創(chuàng)建日期和歸檔方式
  Select Created, Log_Mode, Log_Mode From V$Database;
  
四、ORACLE用戶連接的管理
用系統(tǒng)管理員,查看當(dāng)前數(shù)據(jù)庫有幾個(gè)用戶連接:
SQL> select username,sid,serial# from v$session;
如果要停某個(gè)連接用
SQL> alter system kill session 'sid,serial#'; 如果這命令不行,找它UNIX的進(jìn)程數(shù)
SQL> select pro.spid from v$session ses,v$process pro where
ses.sid=21 and ses.paddr=pro.addr; 說明:21是某個(gè)連接的sid數(shù) 然后用 kill 命令殺此進(jìn)程號(hào)。
五、SQL*PLUS使用
a、近入SQL*Plus
$sqlplus 用戶名/密碼 退出SQL*Plus
SQL>exit b、在sqlplus下得到幫助信息
列出全部SQL命令和SQL*Plus命令
SQL>help
列出某個(gè)特定的命令的信息
SQL>help 命令名 c、顯示表結(jié)構(gòu)命令DESCRIBE
SQL>DESC 表名 d、SQL*Plus中的編輯命令
顯示SQL緩沖區(qū)命令
SQL>L 修改SQL命令
首先要將待改正行變?yōu)楫?dāng)前行
SQL>n
用CHANGE命令修改內(nèi)容
SQL>c/舊/新
重新確認(rèn)是否已正確
SQL>L 使用INPUT命令可以在SQL緩沖區(qū)中增加一行或多行
SQL>i
SQL>輸入內(nèi)容 e、調(diào)用外部系統(tǒng)編輯器 SQL>edit 文件名
可以使用DEFINE命令設(shè)置系統(tǒng)變量EDITOR來改變文本編輯器的類型,在login.sql文件中定義如下一行
DEFINE_EDITOR=vi f、運(yùn)行命令文件
SQL>START test
SQL>@test 常用SQL*Plus語句
a、表的創(chuàng)建、修改、刪除
創(chuàng)建表的命令格式如下:
create table 表名 (列說明列表); 為基表增加新列命令如下:
ALTER TABLE 表名 ADD (列說明列表)
例:為test表增加一列Age,用來存放年齡
??? sql>alter table test
??????? add (Age number(3)); 修改基表列定義命令如下:
ALTER TABLE 表名
MODIFY (列名 數(shù)據(jù)類型)
例:將test表中的Count列寬度加長為10個(gè)字符
??? sql>alter atble test
??????? modify (County char(10)); b、將一張表刪除語句的格式如下:
DORP TABLE 表名;
例:表刪除將同時(shí)刪除表的數(shù)據(jù)和表的定義
sql>drop table test c、表空間的創(chuàng)建、刪除 六、ORACLE邏輯備份的SH文件
完全備份的SH文件:exp_comp.sh rq=` date +"%m%d" ` su - oracle -c "exp system/manager full=y inctype=complete
file=/oracle/export/db_comp$rq.dmp" 累計(jì)備份的SH文件:exp_cumu.sh rq=` date +"%m%d" ` su - oracle -c "exp system/manager full=y inctype=cumulative
file=/oracle/export/db_cumu$rq.dmp" 增量備份的SH文件: exp_incr.sh rq=` date +"%m%d" ` su - oracle -c "exp system/manager full=y inctype=incremental
file=/oracle/export/db_incr$rq.dmp" root用戶crontab文件
/var/spool/cron/crontabs/root增加以下內(nèi)容 0 2 1 * * /oracle/exp_comp.sh 30 2 * * 0-5 /oracle/exp_incr.sh 45 2 * * 6 /oracle/exp_cumu.sh 當(dāng)然這個(gè)時(shí)間表可以根據(jù)不同的需求來改變的,這只是一個(gè)例子。 七、ORACLE 常用的SQL語法和數(shù)據(jù)對(duì)象
一.數(shù)據(jù)控制語句 (DML) 部分
1.INSERT (往數(shù)據(jù)表里插入記錄的語句) INSERT INTO 表名(字段名1, 字段名2, ……) VALUES ( 值1, 值2, ……);
INSERT INTO 表名(字段名1, 字段名2, ……) SELECT (字段名1, 字段名2, ……) FROM 另外的表名; 字符串類型的字段值必須用單引號(hào)括起來, 例如: ’GOOD DAY’
如果字段值里包含單引號(hào)’ 需要進(jìn)行字符串轉(zhuǎn)換, 我們把它替換成兩個(gè)單引號(hào)''.
字符串類型的字段值超過定義的長度會(huì)出錯(cuò), 最好在插入前進(jìn)行長度校驗(yàn). 日期字段的字段值可以用當(dāng)前數(shù)據(jù)庫的系統(tǒng)時(shí)間SYSDATE, 精確到秒
或者用字符串轉(zhuǎn)換成日期型函數(shù)TO_DATE(‘2001-08-01’,’YYYY-MM-DD’)
TO_DATE()還有很多種日期格式, 可以參看ORACLE DOC.
年-月-日 小時(shí):分鐘:秒 的格式Y(jié)YYY-MM-DD HH24:MI:SS INSERT時(shí)最大可操作的字符串長度小于等于4000個(gè)單字節(jié), 如果要插入更長的字符串, 請(qǐng)考慮字段用CLOB類型,
方法借用ORACLE里自帶的DBMS_LOB程序包. INSERT時(shí)如果要用到從1開始自動(dòng)增長的序列號(hào), 應(yīng)該先建立一個(gè)序列號(hào)
CREATE SEQUENCE 序列號(hào)的名稱 (最好是表名+序列號(hào)標(biāo)記) INCREMENT BY 1 START WITH 1
MAXVALUE 99999 CYCLE NOCACHE;
其中最大的值按字段的長度來定, 如果定義的自動(dòng)增長的序列號(hào) NUMBER(6) , 最大值為999999 INSERT 語句插入這個(gè)字段值為: 序列號(hào)的名稱.NEXTVAL 2.DELETE (刪除數(shù)據(jù)表里記錄的語句) DELETE FROM表名 WHERE 條件; 注意:刪除記錄并不能釋放ORACLE里被占用的數(shù)據(jù)塊表空間. 它只把那些被刪除的數(shù)據(jù)塊標(biāo)成unused. 如果確實(shí)要?jiǎng)h除一個(gè)大表里的全部記錄, 可以用 TRUNCATE 命令, 它可以釋放占用的數(shù)據(jù)塊表空間
TRUNCATE TABLE 表名;
此操作不可回退. 3.UPDATE (修改數(shù)據(jù)表里記錄的語句) UPDATE表名 SET 字段名1=值1, 字段名2=值2, …… WHERE 條件; 如果修改的值N沒有賦值或定義時(shí), 將把原來的記錄內(nèi)容清為NULL, 最好在修改前進(jìn)行非空校驗(yàn);
值N超過定義的長度會(huì)出錯(cuò), 最好在插入前進(jìn)行長度校驗(yàn).. 注意事項(xiàng):
A.??????? 以上SQL語句對(duì)表都加上了行級(jí)鎖,
??????? 確認(rèn)完成后, 必須加上事物處理結(jié)束的命令 COMMIT 才能正式生效,
??????? 否則改變不一定寫入數(shù)據(jù)庫里.
??????? 如果想撤回這些操作, 可以用命令 ROLLBACK 復(fù)原. B.??????? 在運(yùn)行INSERT, DELETE 和 UPDATE 語句前最好估算一下可能操作的記錄范圍,
??????? 應(yīng)該把它限定在較小 (一萬條記錄) 范圍內(nèi),. 否則ORACLE處理這個(gè)事物用到很大的回退段.
??????? 程序響應(yīng)慢甚至失去響應(yīng). 如果記錄數(shù)上十萬以上這些操作, 可以把這些SQL語句分段分次完成,
??????? 其間加上COMMIT 確認(rèn)事物處理.
二.數(shù)據(jù)定義 (DDL) 部分
1.CREATE (創(chuàng)建表, 索引, 視圖, 同義詞, 過程, 函數(shù), 數(shù)據(jù)庫鏈接等) ORACLE常用的字段類型有
CHAR??????????????????????? 固定長度的字符串
VARCHAR2??????????????? 可變長度的字符串
NUMBER(M,N)??????????????? 數(shù)字型M是位數(shù)總長度, N是小數(shù)的長度
DATE??????????????????????? 日期類型
創(chuàng)建表時(shí)要把較小的不為空的字段放在前面, 可能為空的字段放在后面
創(chuàng)建表時(shí)可以用中文的字段名, 但最好還是用英文的字段名
創(chuàng)建表時(shí)可以給字段加上默認(rèn)值, 例如 DEFAULT SYSDATE
這樣每次插入和修改時(shí), 不用程序操作這個(gè)字段都能得到動(dòng)作的時(shí)間
創(chuàng)建表時(shí)可以給字段加上約束條件
例如 不允許重復(fù) UNIQUE, 關(guān)鍵字 PRIMARY KEY 2.ALTER??????? (改變表, 索引, 視圖等) 改變表的名稱
ALTER TABLE 表名1 TO 表名2;
在表的后面增加一個(gè)字段
ALTER TABLE表名 ADD 字段名 字段名描述; 修改表里字段的定義描述
ALTER TABLE表名 MODIFY字段名 字段名描述; 給表里的字段加上約束條件
ALTER TABLE 表名 ADD CONSTRAINT 約束名 PRIMARY KEY (字段名);
ALTER TABLE 表名 ADD CONSTRAINT 約束名 UNIQUE (字段名); 把表放在或取出數(shù)據(jù)庫的內(nèi)存區(qū)
ALTER TABLE 表名 CACHE;
ALTER TABLE 表名 NOCACHE; 3.DROP??????? (刪除表, 索引, 視圖, 同義詞, 過程, 函數(shù), 數(shù)據(jù)庫鏈接等) 刪除表和它所有的約束條件
DROP TABLE 表名 CASCADE CONSTRAINTS; 4.TRUNCATE (清空表里的所有記錄, 保留表的結(jié)構(gòu)) TRUNCATE 表名; 三.查詢語句 (SELECT) 部分
SELECT字段名1, 字段名2, …… FROM 表名1, [表名2, ……] WHERE 條件; 字段名可以帶入函數(shù)
例如: COUNT(*), MIN(字段名), MAX(字段名), AVG(字段名), DISTINCT(字段名),
?????????? TO_CHAR(DATE字段名,'YYYY-MM-DD HH24:MI:SS') NVL(EXPR1, EXPR2)函數(shù)
解釋:
IF EXPR1=NULL
??????????????? RETURN EXPR2
ELSE
?????????????????????? RETURN EXPR1 DECODE(AA﹐V1﹐R1﹐V2﹐R2....)函數(shù)
解釋:
IF AA=V1 THEN RETURN R1
IF AA=V2 THEN RETURN R2
..…
ELSE
RETURN NULL LPAD(char1,n,char2)函數(shù)
解釋:
字符char1按制定的位數(shù)n顯示,不足的位數(shù)用char2字符串替換左邊的空位 字段名之間可以進(jìn)行算術(shù)運(yùn)算
例如: (字段名1*字段名1)/3 查詢語句可以嵌套
例如: SELECT …… FROM
(SELECT …… FROM表名1, [表名2, ……] WHERE 條件) WHERE 條件2;
bitsCN_com關(guān)注網(wǎng)管是我們的使命 兩個(gè)查詢語句的結(jié)果可以做集合操作
例如: 并集UNION(去掉重復(fù)記錄), 并集UNION ALL(不去掉重復(fù)記錄), 差集MINUS, 交集INTERSECT 分組查詢
SELECT字段名1, 字段名2, …… FROM 表名1, [表名2, ……] GROUP BY字段名1
[HAVING 條件] ; 兩個(gè)以上表之間的連接查詢 SELECT字段名1, 字段名2, …… FROM 表名1, [表名2, ……] WHERE
??????????????? 表名1.字段名 = 表名2. 字段名 [ AND ……] ; SELECT字段名1, 字段名2, …… FROM 表名1, [表名2, ……] WHERE
??????????????? 表名1.字段名 = 表名2. 字段名(+) [ AND ……] ; 有(+)號(hào)的字段位置自動(dòng)補(bǔ)空值 查詢結(jié)果集的排序操作, 默認(rèn)的排序是升序ASC, 降序是DESC SELECT字段名1, 字段名2, …… FROM 表名1, [表名2, ……]
ORDER BY字段名1, 字段名2 DESC; 字符串模糊比較的方法 INSTR(字段名, ‘字符串’)>0
字段名 LIKE ‘字符串%’ [‘%字符串%’] 每個(gè)表都有一個(gè)隱含的字段ROWID, 它標(biāo)記著記錄的唯一性. 四.ORACLE里常用的數(shù)據(jù)對(duì)象 (SCHEMA)
1.索引 (INDEX)
CREATE INDEX 索引名ON 表名 ( 字段1, [字段2, ……] );
ALTER INDEX 索引名 REBUILD; 一個(gè)表的索引最好不要超過三個(gè) (特殊的大表除外), 最好用單字段索引, 結(jié)合SQL語句的分析執(zhí)行情況,
也可以建立多字段的組合索引和基于函數(shù)的索引 ORACLE8.1.7字符串可以索引的最大長度為1578 單字節(jié)
ORACLE8.0.6字符串可以索引的最大長度為758 單字節(jié) 2.視圖 (VIEW)
CREATE VIEW 視圖名AS SELECT …. FROM …..;
ALTER VIEW視圖名 COMPILE; 視圖僅是一個(gè)SQL查詢語句, 它可以把表之間復(fù)雜的關(guān)系簡潔化. 3.同義詞 (SYNONMY)
CREATE SYNONYM同義詞名FOR 表名;
CREATE SYNONYM同義詞名FOR 表名@數(shù)據(jù)庫鏈接名; 4.數(shù)據(jù)庫鏈接 (DATABASE LINK)
CREATE DATABASE LINK數(shù)據(jù)庫鏈接名CONNECT TO 用戶名 IDENTIFIED BY 密碼 USING
‘?dāng)?shù)據(jù)庫連接字符串’; 數(shù)據(jù)庫連接字符串可以用NET8 EASY CONFIG或者直接修改TNSNAMES.ORA里定義. 數(shù)據(jù)庫參數(shù)global_name=true時(shí)要求數(shù)據(jù)庫鏈接名稱跟遠(yuǎn)端數(shù)據(jù)庫名稱一樣 數(shù)據(jù)庫全局名稱可以用以下命令查出
SELECT * FROM GLOBAL_NAME; 查詢遠(yuǎn)端數(shù)據(jù)庫里的表
SELECT …… FROM 表名@數(shù)據(jù)庫鏈接名; http://www.bitscn.net/網(wǎng)管博客等你來搏 五.權(quán)限管理 (DCL) 語句
1.GRANT??????? 賦于權(quán)限
常用的系統(tǒng)權(quán)限集合有以下三個(gè):
CONNECT(基本的連接), RESOURCE(程序開發(fā)), DBA(數(shù)據(jù)庫管理)
常用的數(shù)據(jù)對(duì)象權(quán)限有以下五個(gè):
ALL???????? ON 數(shù)據(jù)對(duì)象名,???????? SELECT ON 數(shù)據(jù)對(duì)象名,???????? UPDATE ON
數(shù)據(jù)對(duì)象名,
DELETE???????? ON 數(shù)據(jù)對(duì)象名, INSERT ON 數(shù)據(jù)對(duì)象名,?? ALTER ON 數(shù)據(jù)對(duì)象名 GRANT CONNECT, RESOURCE TO 用戶名;
GRANT SELECT ON 表名 TO 用戶名;
GRANT SELECT, INSERT, DELETE ON表名 TO 用戶名1, 用戶名2; 2.REVOKE 回收權(quán)限 REVOKE CONNECT, RESOURCE FROM 用戶名;
REVOKE SELECT ON 表名 FROM 用戶名;
REVOKE SELECT, INSERT, DELETE ON表名 FROM 用戶名1, 用戶名2; 查詢數(shù)據(jù)庫中第63號(hào)錯(cuò)誤:
select orgaddr,destaddr from sm_histable0116 where error_code='63'; 查詢數(shù)據(jù)庫中開戶用戶最大提交和最大下發(fā)數(shù): select MSISDN,TCOS,OCOS from ms_usertable; 查詢數(shù)據(jù)庫中各種錯(cuò)誤代碼的總和:
bitsCN_com select error_code,count(*) from sm_histable0513 group by error_code order by error_code; 查詢報(bào)表數(shù)據(jù)庫中話單統(tǒng)計(jì)種類查詢。
select sum(Successcount) from tbl_MiddleMt0411 where ServiceType2=111
select sum(successcount),servicetype from tbl_middlemt0411 group by servicetype


我們通常所說的DML、DDL、DCL語句都是sql*plus語句,它們執(zhí)行完后,都可以保存在一個(gè)被稱為sql buffer的內(nèi)存區(qū)域中,并且只能保存一條最近執(zhí)行的sql語句,我們可以對(duì)保存在sql buffer中的sql 語句進(jìn)行修改,然后再次執(zhí)行,sqlplus一般都與數(shù)據(jù)庫打交道。

常用:

sqlplus username/password? 如:普通用戶登錄? sqlplus scott/tiger

sqlplus username/password@net_service_name 如: sqlplus scott/tiger@orcl
sqlplus? username/password as sysdba 如:sqlplus sys/admin as sysdba

sqlplus username/password@//host:port/sid

注意:sys和system需要以sysdba登錄

在進(jìn)入sql*plus之后,可以使用conn連接到其他用戶,如:conn sys/admin as sysdba

在DOS環(huán)境下,輸入“sqlplus /?”,如下:

C:\Documents and Settings\HH>sqlplus /?
SQL*Plus: Release 11.2.0.1.0 Production on 星期六 8月 13 16:56:46 2011
Copyright (c) 1982, 2010, Oracle.? All rights reserved.
SQL*Plus: Release 11.2.0.1.0 Production
Copyright (c) 1982, 2010, Oracle.? All rights reserved.
使用 SQL*Plus 執(zhí)行 SQL, PL/SQL 和 SQL*Plus 語句。
用法 1: sqlplus -H | -V
??? -H???????????? 顯示 SQL*Plus 版本和用法幫助。
??? -V???????????? 顯示 SQL*Plus 版本。

用法 2: sqlplus [ [<option>] [{logon | /nolog}] [<start>] ]

? <option> 為: [-C <version>] [-L] [-M "<options>"] [-R <level>] [-S]

??? -C <version>?? 將受影響的命令的兼容性設(shè)置為<version> 指定的版本。該版本具有"x.y[.z]" 格式。例如, -C 10.2.0
??? -L???????????? 只嘗試登錄一次, 而不是 在出錯(cuò)時(shí)再次提示。
??? -M "<options>" 設(shè)置輸出的自動(dòng) HTML 標(biāo)記。選項(xiàng)的格式為:
?????????????????? HTML [ON|OFF] [HEAD text] [BODY text] [TABLE text][ENTMAP {ON|OFF}] [SPOOL {ON|OFF}] [PRE[FORMAT] {ON|OFF}]
??? -R <level>???? 設(shè)置受限模式, 以禁用與文件系統(tǒng)交互的SQL*Plus 命令。級(jí)別可以是 1, 2 或 3。最高限制級(jí)別為 -R 3, 該級(jí)別禁用與文件系統(tǒng)交互的所有用戶命令。
??? -S???????????? 設(shè)置無提示模式, 該模式隱藏命令的 SQL*Plus 標(biāo)幟, 提示和回顯 的顯示。

?<logon> 為: {<username>[/<password>][@<connect_identifier>] | / }[AS {SYSDBA | SYSOPER | SYSASM}] [EDITION=value]
?? 指定數(shù)據(jù)庫帳戶用戶名, 口令和數(shù)據(jù)庫連接的連接標(biāo)識(shí)符。如果沒有連接標(biāo)識(shí)符, SQL*Plus 將連接到默認(rèn)數(shù)據(jù)庫。
?? AS SYSDBA, AS SYSOPER 和 AS SYSASM 選項(xiàng)是數(shù)據(jù)庫管理權(quán)限。
?? <connect_identifier> 的形式可以是 Net 服務(wù)名或輕松連接。
???? @[<net_service_name> | [//]Host[:Port]/<service_name>]
?????? <net_service_name> 是服務(wù)的簡單名稱, 它解析為連接描述符。
?????? 示例: 使用 Net 服務(wù)名連接到數(shù)據(jù)庫, 且數(shù)據(jù)庫 Net 服務(wù)名為 ORCL。
????????? sqlplus myusername/mypassword@ORCL

?????? Host 指定數(shù)據(jù)庫服務(wù)器計(jì)算機(jī)的主機(jī)名或 IP地址。
?????? Port 指定數(shù)據(jù)庫服務(wù)器上的監(jiān)聽端口。
?????? <service_name> 指定要訪問的數(shù)據(jù)庫的服務(wù)名。
?????? 示例: 使用輕松連接連接到數(shù)據(jù)庫, 且服務(wù)名為 ORCL。
????????? sqlplus myusername/mypassword@Host/ORCL
?? /NOLOG 選項(xiàng)可啟動(dòng) SQL*Plus 而不連接到數(shù)據(jù)庫。
?? EDITION 指定會(huì)話版本的值。
?<start> 為: @<URL>|<filename>[.<ext>] [<parameter> ...]
?? 使用將分配給腳本中的替代變量的指定參數(shù)從 Web 服務(wù)器 (URL) 或本地文件系統(tǒng) (filename.ext)運(yùn)行指定的 SQL*Plus 腳本。
在啟動(dòng) SQL*Plus 并且執(zhí)行 CONNECT 命令后, 將運(yùn)行站點(diǎn)概要文件 (例如, $ORACLE_HOME/sqlplus/admin/glogin.sql) 和用戶概要文件例如, 工作目錄中的 login.sql)。這些文件包含 SQL*Plus 命令。

除了sqlplus語句,在sql*plus中執(zhí)行的其它語句我們稱之為sql*plus命令。它們執(zhí)行完后,不保存在sql buffer的內(nèi)存區(qū)域中,它們一般用來對(duì)輸出的結(jié)果進(jìn)行格式化顯示,以便于制作報(bào)表。

下面就介紹一下一些常用的sql*plus命令:

1. 執(zhí)行一個(gè)SQL腳本文件
SQL>start file_name
SQL>@ file_name
我們可以將多條sql語句保存在一個(gè)文本文件中,這樣當(dāng)要執(zhí)行這個(gè)文件中的所有的sql語句時(shí),用上面的任一命令即可,這類似于dos中的批處理。
2. 對(duì)當(dāng)前的輸入進(jìn)行編輯
SQL>edit
3. 重新運(yùn)行上一次運(yùn)行的sql語句
SQL>/
4. 將顯示的內(nèi)容輸出到指定文件
SQL> SPOOL file_name
在屏幕上的所有內(nèi)容都包含在該文件中,包括你輸入的sql語句。
5. 關(guān)閉spool輸出
SQL> SPOOL OFF
只有關(guān)閉spool輸出,才會(huì)在輸出文件中看到輸出的內(nèi)容。
6.顯示一個(gè)表的結(jié)構(gòu)
SQL> desc table_name
7. COL命令:
主要格式化列的顯示形式。
該命令有許多選項(xiàng),具體如下:
COL[UMN] [{ column|expr} [ option ...]]
Option選項(xiàng)可以是如下的子句:
ALI[AS] alias
CLE[AR]
FOLD_A[FTER]
FOLD_B[EFORE]
FOR[MAT] format
HEA[DING] text
JUS[TIFY] {L[EFT]|C[ENTER]|C[ENTRE]|R[IGHT]}
LIKE { expr|alias}
NEWL[INE]
NEW_V[ALUE] variable
NOPRI[NT]|PRI[NT]
NUL[L] text
OLD_V[ALUE] variable
ON|OFF
WRA[PPED]|WOR[D_WRAPPED]|TRU[NCATED]
1). 改變?nèi)笔〉牧袠?biāo)題
COLUMN column_name HEADING column_heading
For example:
Sql>select * from dept;
DEPTNO DNAME LOC
---------- ---------------------------- ---------
10 ACCOUNTING NEW YORK
sql>col LOC heading location
sql>select * from dept;
DEPTNO DNAME location
--------- ---------------------------- -----------
10 ACCOUNTING NEW YORK
2). 將列名ENAME改為新列名EMPLOYEE NAME并將新列名放在兩行上:
Sql>select * from emp
Department name Salary
---------- ---------- ----------
10 aaa 11
SQL> COLUMN ENAME HEADING 'Employee|Name'
Sql>select * from emp
Employee
Department name Salary
---------- ---------- ----------
10 aaa 11
note: the col heading turn into two lines from one line.
3). 改變列的顯示長度:
FOR[MAT] format
Sql>select empno,ename,job from emp;
EMPNO ENAME JOB
---------- ---------- ---------
7369 SMITH CLERK
7499 ALLEN SALESMAN
7521 WARD SALESMAN
Sql> col ename format a40
EMPNO ENAME JOB
---------- ---------------------------------------- ---------
7369 SMITH CLERK
7499 ALLEN SALESMAN
7521 WARD SALESMAN
4). 設(shè)置列標(biāo)題的對(duì)齊方式
JUS[TIFY] {L[EFT]|C[ENTER]|C[ENTRE]|R[IGHT]}
SQL> col ename justify center
SQL> /
EMPNO ENAME JOB
---------- ---------------------------------------- ---------
7369 SMITH CLERK
7499 ALLEN SALESMAN
7521 WARD SALESMAN
對(duì)于NUMBER型的列,列標(biāo)題缺省在右邊,其它類型的列標(biāo)題缺省在左邊
5). 不讓一個(gè)列顯示在屏幕上
NOPRI[NT]|PRI[NT]
SQL> col job noprint
SQL> /
EMPNO ENAME
---------- ----------------------------------------
7369 SMITH
7499 ALLEN
7521 WARD
6). 格式化NUMBER類型列的顯示:
SQL> COLUMN SAL FORMAT $99,990
SQL> /
Employee
Department Name Salary Commission
---------- ---------- --------- ----------
30 ALLEN $1,600 300
7). 顯示列值時(shí),如果列值為NULL值,用text值代替NULL值
COMM NUL[L] text
SQL>COL COMM NUL[L] text
. 設(shè)置一個(gè)列的回繞方式
WRA[PPED]|WOR[D_WRAPPED]|TRU[NCATED]
COL1
--------------------
HOW ARE YOU?
SQL>COL COL1 FORMAT A5
SQL>COL COL1 WRAPPED
COL1
-----
HOW A
RE YO
U?
SQL> COL COL1 WORD_WRAPPED
COL1
-----
HOW
ARE
YOU?
SQL> COL COL1 WORD_WRAPPED
COL1
-----
HOW A
9). 顯示列的當(dāng)前的顯示屬性值
SQL> COLUMN column_name
10). 將所有列的顯示屬性設(shè)為缺省值
SQL> CLEAR COLUMNS
8. 屏蔽掉一個(gè)列中顯示的相同的值
BREAK ON break_column
SQL> BREAK ON DEPTNO
SQL> SELECT DEPTNO, ENAME, SAL
FROM EMP
WHERE SAL < 2500
ORDER BY DEPTNO;
DEPTNO ENAME SAL
---------- ----------- ---------
10 CLARK 2450
MILLER 1300
20 SMITH 800
ADAMS 1100
9. 在上面屏蔽掉一個(gè)列中顯示的相同的值的顯示中,每當(dāng)列值變化時(shí)在值變化之前插入n個(gè)空行。
BREAK ON break_column SKIP n
SQL> BREAK ON DEPTNO SKIP 1
SQL> /
DEPTNO ENAME SAL
---------- ----------- ---------
10 CLARK 2450
MILLER 1300
20 SMITH 800
ADAMS 1100
10. 顯示對(duì)BREAK的設(shè)置
SQL> BREAK
11. 刪除6、7的設(shè)置
SQL> CLEAR BREAKS
12. Set 命令:
該命令包含許多子命令:
SET system_variable value
system_variable value 可以是如下的子句之一:
APPI[NFO]{ON|OFF|text}
ARRAY[SIZE] {15|n}
AUTO[COMMIT]{ON|OFF|IMM[EDIATE]|n}
AUTOP[RINT] {ON|OFF}
AUTORECOVERY [ON|OFF]
AUTOT[RACE] {ON|OFF|TRACE[ONLY]} [EXP[LAIN]] [STAT[ISTICS]]
BLO[CKTERMINATOR] {.|c}
CMDS[EP] {;|c|ON|OFF}
COLSEP {_|text}
COM[PATIBILITY]{V7|V8|NATIVE}
CON[CAT] {.|c|ON|OFF}
COPYC[OMMIT] {0|n}
COPYTYPECHECK {ON|OFF}
DEF[INE] {&|c|ON|OFF}
DESCRIBE [DEPTH {1|n|ALL}][LINENUM {ON|OFF}][INDENT {ON|OFF}]
ECHO {ON|OFF}
EDITF[ILE] file_name[.ext]
EMB[EDDED] {ON|OFF}
ESC[APE] {|c|ON|OFF}
FEED[BACK] {6|n|ON|OFF}
FLAGGER {OFF|ENTRY |INTERMED[IATE]|FULL}
FLU[SH] {ON|OFF}
HEA[DING] {ON|OFF}
HEADS[EP] {||c|ON|OFF}
INSTANCE [instance_path|LOCAL]
LIN[ESIZE] {80|n}
LOBOF[FSET] {n|1}
LOGSOURCE [pathname]
LONG {80|n}
LONGC[HUNKSIZE] {80|n}
MARK[UP] HTML [ON|OFF] [HEAD text] [BODY text] [ENTMAP {ON|OFF}] [SPOOL
{ON|OFF}] [PRE[FORMAT] {ON|OFF}]
NEWP[AGE] {1|n|NONE}
NULL text
NUMF[ORMAT] format
NUM[WIDTH] {10|n}
PAGES[IZE] {24|n}
PAU[SE] {ON|OFF|text}
RECSEP {WR[APPED]|EA[CH]|OFF}
RECSEPCHAR {_|c}
SERVEROUT[PUT] {ON|OFF} [SIZE n] [FOR[MAT] {WRA[PPED]|WOR[D_
WRAPPED]|TRU[NCATED]}]
SHIFT[INOUT] {VIS[IBLE]|INV[ISIBLE]}
SHOW[MODE] {ON|OFF}
SQLBL[ANKLINES] {ON|OFF}
SQLC[ASE] {MIX[ED]|LO[WER]|UP[PER]}
SQLCO[NTINUE] {> |text}
SQLN[UMBER] {ON|OFF}
SQLPRE[FIX] {#|c}
SQLP[ROMPT] {SQL>|text}
SQLT[ERMINATOR] {;|c|ON|OFF}
SUF[FIX] {SQL|text}
TAB {ON|OFF}
TERM[OUT] {ON|OFF}
TI[ME] {ON|OFF}
TIMI[NG] {ON|OFF}
TRIM[OUT] {ON|OFF}
TRIMS[POOL] {ON|OFF}
UND[ERLINE] {-|c|ON|OFF}
VER[IFY] {ON|OFF}
WRA[P] {ON|OFF}
1). 設(shè)置當(dāng)前session是否對(duì)修改的數(shù)據(jù)進(jìn)行自動(dòng)提交
SQL>SET AUTO[COMMIT] {ON|OFF|IMM[EDIATE]| n}
2).在用start命令執(zhí)行一個(gè)sql腳本時(shí),是否顯示腳本中正在執(zhí)行的SQL語句
SQL> SET ECHO {ON|OFF}
3).是否顯示當(dāng)前sql語句查詢或修改的行數(shù)
SQL> SET FEED[BACK] {6|n|ON|OFF}
默認(rèn)只有結(jié)果大于6行時(shí)才顯示結(jié)果的行數(shù)。如果set feedback 1 ,則不管查詢到多少行都返回。當(dāng)為off 時(shí),一律不顯示查詢的行數(shù)
4).是否顯示列標(biāo)題
SQL> SET HEA[DING] {ON|OFF}
當(dāng)set heading off 時(shí),在每頁的上面不顯示列標(biāo)題,而是以空白行代替
5).設(shè)置一行可以容納的字符數(shù)
SQL> SET LIN[ESIZE] {80|n}
如果一行的輸出內(nèi)容大于設(shè)置的一行可容納的字符數(shù),則折行顯示。
6).設(shè)置頁與頁之間的分隔
SQL> SET NEWP[AGE] {1|n|NONE}
當(dāng)set newpage 0 時(shí),會(huì)在每頁的開頭有一個(gè)小的黑方框。
當(dāng)set newpage n 時(shí),會(huì)在頁和頁之間隔著n個(gè)空行。
當(dāng)set newpage none 時(shí),會(huì)在頁和頁之間沒有任何間隔。
7).顯示時(shí),用text值代替NULL值
SQL> SET NULL text
.設(shè)置一頁有多少行數(shù)
SQL> SET PAGES[IZE] {24|n}
如果設(shè)為0,則所有的輸出內(nèi)容為一頁并且不顯示列標(biāo)題
9).是否顯示用DBMS_OUTPUT.PUT_LINE包進(jìn)行輸出的信息。
SQL> SET SERVEROUT[PUT] {ON|OFF}
在編寫存儲(chǔ)過程時(shí),我們有時(shí)會(huì)用dbms_output.put_line將必要的信息輸出,以便對(duì)存儲(chǔ)過程進(jìn)行調(diào)試,只有將serveroutput變量設(shè)為on后,信息才能顯示在屏幕上。 dbms_output.put_line會(huì)"吃掉"最前面的空格?在set serveroutput on后加上format wrapped參數(shù)!
10).當(dāng)SQL語句的長度大于LINESIZE時(shí),是否在顯示時(shí)截取SQL語句。
SQL> SET WRA[P] {ON|OFF}
當(dāng)輸出的行的長度大于設(shè)置的行的長度時(shí)(用set linesize n命令設(shè)置),當(dāng)set wrap on時(shí),輸出行的多于的字符會(huì)另起一行顯示,否則,會(huì)將輸出行的多于字符切除,不予顯示。
11).是否在屏幕上顯示輸出的內(nèi)容,主要用與SPOOL結(jié)合使用。
SQL> SET TERM[OUT] {ON|OFF}
在用spool命令將一個(gè)大表中的內(nèi)容輸出到一個(gè)文件中時(shí),將內(nèi)容輸出在屏幕上會(huì)耗費(fèi)大量的時(shí)間,設(shè)置set termspool off后,則輸出的內(nèi)容只會(huì)保存在輸出文件中,不會(huì)顯示在屏幕上,極大的提高了spool的速度。
12).將SPOOL輸出中每行后面多余的空格去掉
SQL> SET TRIMS[OUT] {ON|OFF}
13)顯示每個(gè)sql語句花費(fèi)的執(zhí)行時(shí)間
set TIMING {ON|OFF}
14.修改sql buffer中的當(dāng)前行中,第一個(gè)出現(xiàn)的字符串
C[HANGE] /old_value/new_value
SQL> l
1* select * from dept
SQL> c/dept/emp
1* select * from emp
15.編輯sql buffer中的sql語句
EDI[T]
16.顯示sql buffer中的sql語句,list n顯示sql buffer中的第n行,并使第n行成為當(dāng)前行
L[IST] [n]
17.在sql buffer的當(dāng)前行下面加一行或多行
I[NPUT]
18.將指定的文本加到sql buffer的當(dāng)前行后面
A[PPEND]
SQL> select deptno,
2 dname
3 from dept;
DEPTNO DNAME
---------- --------------
10 ACCOUNTING
20 RESEARCH
30 SALES
40 OPERATIONS
SQL> L 2
2* dname
SQL> a ,loc
2* dname,loc
SQL> L
1 select deptno,
2 dname,loc
3* from dept
SQL> /
DEPTNO DNAME LOC
---------- -------------- -------------
10 ACCOUNTING NEW YORK
20 RESEARCH DALLAS
30 SALES CHICAGO
40 OPERATIONS BOSTON
19.將sql buffer中的sql語句保存到一個(gè)文件中
SAVE file_name
20.將一個(gè)文件中的sql語句導(dǎo)入到sql buffer中
GET file_name
21.再次執(zhí)行剛才已經(jīng)執(zhí)行的sql語句
RUN
or
/
22.執(zhí)行一個(gè)存儲(chǔ)過程
EXECUTE procedure_name
23.在sql*plus中連接到指定的數(shù)據(jù)庫
CONNECT user_name/passwd@db_alias
24.設(shè)置每個(gè)報(bào)表的頂部標(biāo)題
TTITLE
25.設(shè)置每個(gè)報(bào)表的尾部標(biāo)題
BTITLE
26.寫一個(gè)注釋
REMARK [text]
27.將指定的信息或一個(gè)空行輸出到屏幕上
PROMPT [text]
28.將執(zhí)行的過程暫停,等待用戶響應(yīng)后繼續(xù)執(zhí)行
PAUSE [text]
Sql>PAUSE Adjust paper and press RETURN to continue.
29.將一個(gè)數(shù)據(jù)庫中的一些數(shù)據(jù)拷貝到另外一個(gè)數(shù)據(jù)庫(如將一個(gè)表的數(shù)據(jù)拷貝到另一個(gè)數(shù)據(jù)庫)
COPY {FROM database | TO database | FROM database TO database}
{APPEND|CREATE|INSERT|REPLACE} destination_table
[(column, column, column, ...)] USING query
sql>COPY FROM SCOTT/TIGER@HQ TO JOHN/CHROME@WEST
create emp_temp
USING SELECT * FROM EMP
30.不退出sql*plus,在sql*plus中執(zhí)行一個(gè)操作系統(tǒng)命令:
HOST
Sql> host hostname
該命令在windows下可能被支持。
31.在sql*plus中,切換到操作系統(tǒng)命令提示符下,運(yùn)行操作系統(tǒng)命令后,可以再次切換回sql*plus:

sql>!
$hostname
$exit
sql>
該命令在windows下不被支持。
32.顯示sql*plus命令的幫助
HELP
如何安裝幫助文件:
Sql>@ ?sqlplusadminhelphlpbld.sql ?sqlplusadminhelphelpus.sql
Sql>help index
33.顯示sql*plus系統(tǒng)變量的值或sql*plus環(huán)境變量的值
Syntax
SHO[W] option
where option represents one of the following terms or clauses:
system_variable
ALL
BTI[TLE]
ERR[ORS] [{FUNCTION|PROCEDURE|PACKAGE|PACKAGE BODY|
TRIGGER|VIEW|TYPE|TYPE BODY} [schema.]name]
LNO
PARAMETERS [parameter_name]
PNO
REL[EASE]
REPF[OOTER]
REPH[EADER]
SGA
SPOO[L]
SQLCODE
TTI[TLE]
USER
1) . 顯示當(dāng)前環(huán)境變量的值:
Show all
2) . 顯示當(dāng)前在創(chuàng)建函數(shù)、存儲(chǔ)過程、觸發(fā)器、包等對(duì)象的錯(cuò)誤信息
Show error
當(dāng)創(chuàng)建一個(gè)函數(shù)、存儲(chǔ)過程等出錯(cuò)時(shí),變可以用該命令查看在那個(gè)地方出錯(cuò)及相應(yīng)的出錯(cuò)信息,進(jìn)行修改后再次進(jìn)行編譯。
3) . 顯示初始化參數(shù)的值:
show PARAMETERS [parameter_name]
4) . 顯示數(shù)據(jù)庫的版本:
show REL[EASE]
5) . 顯示SGA的大小
show SGA
6). 顯示當(dāng)前的用戶名
show user
_________________
xsb注:
@2.sql與@@2.sql的區(qū)別:
比如在e:下sqlplus @e:temp1.sql
1.sql里的@2.sql調(diào)用的腳本位于e:目下
@@2.sql調(diào)用的腳本位于e:temp目錄下。


1.create user username identified by password;//建用戶名和密碼oracle ,oracle

  2.grant connect,resource,dba to username;//授權(quán) grant connect,resource,dba,sysdba to username;

  3.connect username/password//進(jìn)入。

  4.select table_name,column_name from user_tab_columns where table_name='TABLE_NAME';//查詢表中的表名,字段名等等。 最后的table_name要大寫。

  5. 如何執(zhí)行腳本SQL文件? SQL>@PATH/filename.sql;

  7.查詢用戶下的所有表 select distinct table_name from user_tab_columns; ===僅顯示一列表名。

8.如何搜索出前N條記錄?
select * from tablename where rownum<n;--足矣。(--是注釋用的標(biāo)記)

  9.查找用戶下的所有表:select * from tab; --查詢?cè)撚脩粝碌乃斜砑耙晥D(顯示表名tname, 類型tabname和clusterid)

  2、顯示當(dāng)前連接用戶

  SQL> show user –不能用在sql窗口 只能用在command命令窗口。

  3、查看系統(tǒng)擁有哪些用戶

  SQL> select * from all_users;

  4、新建用戶并授權(quán)

  SQL> create user a identified by a;(默認(rèn)建在SYSTEM表空間下)

  SQL> grant connect,resource to a;

  5、連接到新用戶

  SQL> conn a/a –或者是connect a/a

  6、查詢當(dāng)前用戶下所有對(duì)象

  SQL> select * from tab; --table或是view

  7、建立第一個(gè)表

  SQL> create table a(a number);

  8、查詢表結(jié)構(gòu)

  SQL> desc a

  9、插入新記錄

  SQL> insert into a values(1);

  10、查詢記錄

  SQL> select * from a;

  11、更改記錄

  SQL> update a set a=2;

  12、刪除記錄

  SQL> delete from a;

  13、回滾

  SQL> roll;

  SQL> rollback;

  14、提交

  SQL> commit;

  select * from

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

  where rank = 2;

  46. 如何在字符串里加回車?

  select 'Welcome to visit'||chr(10)||'www.CSDN.NET' from dual ; --‘||chr(10)||’作為換行符

  53. 如何使select語句使查詢結(jié)果自動(dòng)生成序號(hào)?

  select rownum COL from table; --主要就是oracle中引入了rownum

  54. 如何知道數(shù)據(jù)褲中某個(gè)表所在的tablespace?

  select tablespace_name from user_tables where table_name='TEST'; --table_name名稱要大寫。

  select * from user_tables中有個(gè)字段TABLESPACE_NAME,(oracle);

  select * from dba_segments where …;

  55. 怎么可以快速做一個(gè)和原表一樣的備份表?

  create table new_table as (select * from old_table);

  59. 請(qǐng)問如何修改一張表的主鍵?

  alter table aaa drop constraint aaa_key ;

  alter table aaa add constraint aaa_key primary key(a1,b1) ;

  60. 改變數(shù)據(jù)文件的大小?

  用 ALTER DATABASE .... DATAFILE .... ;

  手工改變數(shù)據(jù)文件的大小,對(duì)于原來的 數(shù)據(jù)文件有沒有損害。

  61. 怎樣查看ORACLE中有哪些程序在運(yùn)行之中?

  查看v$session表

  62. 怎么可以看到數(shù)據(jù)庫有多少個(gè)tablespace?

  select * from dba_tablespaces;

  
  72. 怎樣查看哪些用戶擁有SYSDBA、SYSOPER權(quán)限?

  SQL>conn sys/change_on_install –登不上去

  SQL>select * from V_$PWFILE_USERS;

76. 如何顯示當(dāng)前連接用戶?

  SHOW USER

  77. 如何查看數(shù)據(jù)文件放置的路徑 ?

  col file_name format a50

  SQL> select tablespace_name,file_id,bytes/1024/1024,file_name from dba_data_files order by file_id;

  79. 如何改變一個(gè)字段初始定義的Check范圍?

  SQL> alter table xxx drop constraint constraint_name;

  之后再創(chuàng)建新約束:

  SQL> alter table xxx add constraint constraint_name check();

  83. 如何執(zhí)行腳本SQL文件?

SQL>@所在的文件路徑 /filename.sql;
例如放在E盤的根目錄下則應(yīng)該是
@E:\a.sql;回車就OK了。

  84. 如何快速清空一個(gè)大表?

  SQL>truncate table table_name;

  85. 如何查有多少個(gè)數(shù)據(jù)庫實(shí)例?

  SQL>SELECT * FROM V$INSTANCE;

  86. 如何查詢數(shù)據(jù)庫有多少表?

  SQL>select * from all_tables;

  87. 如何測(cè)試SQL語句執(zhí)行所用的時(shí)間?

  SQL>set timing on ;

  SQL>select * from tablename;

  89. 字符串的連接

  SELECT CONCAT(COL1,COL2) FROM TABLE ;

  SELECT COL1||COL2 FROM TABLE ;

  90. 怎么把select出來的結(jié)果導(dǎo)到一個(gè)文本文件中?

  SQL>SPOOL C:\ABCD.TXT;

  SQL>select * from table;

  SQL >spool off;

  91. 怎樣估算SQL執(zhí)行的I/O數(shù) ?

  SQL>SET AUTOTRACE ON ;

  SQL>SELECT * FROM TABLE;

  OR

  SQL>SELECT * FROM v$filestat ;

  可以查看IO數(shù)

  92. 如何在sqlplus下改變字段大小?

  alter table table_name modify (field_name varchar2(100));

  改大行,改小不行(除非都是空的)

  93. 如何查詢某天的數(shù)據(jù)?

select * from a where trunc(日期字段)=to_date('2003-05-02','yyyy-mm-dd');
若是date型數(shù)據(jù)
insert into bsyear values(to_date('20130427','yyyymmdd'));
或者是insert into bsyear values('27-4月-2013');
  94. sql 語句如何插入全年日期?

  create table BSYEAR (d date);

insert into BSYEAR select to_date('20030101','yyyymmdd')+rownum-1
from all_objects where rownum <= to_char(to_date('20031231','yyyymmdd'),'ddd'); --在表后直接插入365行數(shù)據(jù)日期。
緊急插入幾條重要的:
如何在Oracle中復(fù)制表結(jié)構(gòu)和表數(shù)據(jù)
1. 復(fù)制表結(jié)構(gòu)及其數(shù)據(jù):
create table table_name_new as select * from table_name_old
2. 只復(fù)制表結(jié)構(gòu):
create table table_name_new as select * from table_name_old where 1=2;
或者:
create table table_name_new like table_name_old
3. 只復(fù)制表數(shù)據(jù):
如果兩個(gè)表結(jié)構(gòu)一樣:
insert into table_name_new select * from table_name_old
如果兩個(gè)表結(jié)構(gòu)不一樣:
insert into table_name_new(column1,column2...) select column1,column2... from table_name_old
創(chuàng)建帶主鍵的表:
create table stuInfo(stuID int primary key,stuName varchar2(20),age int);
或是不直接增加主鍵
alter table stuInfo add constraint stuInfo _PK primary key (stuID)
  95. 如果修改表名?

  alter table old_table_name rename to new_table_name;

  

  97. 如何知道用戶擁有的權(quán)限?

  SELECT * FROM dba_sys_privs ; --一個(gè)權(quán)限對(duì)應(yīng)一條數(shù)據(jù),這樣對(duì)于同一個(gè)用戶就有多條數(shù)據(jù)了。

  98. 從網(wǎng)上下載的ORACLE9I與市場(chǎng)上賣的標(biāo)準(zhǔn)版有什么區(qū)別?

  從功能上說沒有區(qū)別,只不過oracle公司有明文規(guī)定;從網(wǎng)站上下載的oracle產(chǎn)品不得用于商業(yè)用途,否則侵權(quán)。

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

SELECT * FROM empLOYEE WHERE ROWNUM < n ORDER BY empno;
Select * from a where rownum<N;

 

  104. 如何統(tǒng)計(jì)兩個(gè)表的記錄總數(shù)?

  select (select count(id) from aa)+(select count(id) from bb) 總數(shù) from dual; --總數(shù)那是沒有單引號(hào)的,雙引號(hào)可以。

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

  select add_months(sysdate,24) from dual; -- 2015/4/27 9:28:52

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

  沒有限制.

  111. 返回大于等于N的最小整數(shù)值?

  SELECT CEIL(N) FROM DUAL;

  112. 返回小于等于N的最小整數(shù)值?

  SELECT FLOOR(N) FROM DUAL;

  113. 返回當(dāng)前月的最后一天?

  SELECT LAST_DAY(SYSDATE) FROM DUAL;

  ;

  115. 如何找數(shù)據(jù)庫表的主鍵字段的名稱?

  SQL>SELECT * FROM user_constraints WHERE CONSTRAINT_TYPE='P' and table_name='TABLE_NAME'; --我沒有查出來。

  116. 兩個(gè)結(jié)果集互加的函數(shù)?

  SQL>SELECT * FROM BSEMPMS_OLD INTERSECT SELECT * FROM BSEMPMS_NEW;

  SQL>SELECT * FROM BSEMPMS_OLD UNION SELECT * FROM BSEMPMS_NEW;

  SQL>SELECT * FROM BSEMPMS_OLD UNION ALL SELECT * FROM BSEMPMS_NEW;

  117. 兩個(gè)結(jié)果集互減的函數(shù)?

  SQL>SELECT * FROM BSEMPMS_OLD MINUS SELECT * FROM BSEMPMS_NEW;

  139. 如何查找重復(fù)記錄?

  SELECT * FROM TABLE_NAME WHERE ROWID!=(SELECT MAX(ROWID) FROM TABLE_NAMe WHERE TABLE_NAME.COL1=D.COL1 AND TABLE_NAME.COL2=D.COL2);

  140. 如何刪除重復(fù)記錄?

  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);


  162. 如何知道表在表空間中的存儲(chǔ)情況?

  select segment_name,sum(bytes),count(*) ext_quan from dba_extents where tablespace_name='&tablespace_name' and segment_type='TABLE' group by tablespace_name,segment_name; --把&tablespace_name改成相應(yīng)的表空間名稱。



總結(jié)

以上是生活随笔為你收集整理的ORACLE SQL*PLUS 命令大全的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。