熱點推薦:
您现在的位置: 電腦知識網 >> 編程 >> Oracle >> 正文

ORACLEsqlplus命令

2022-06-13   來源: Oracle 

  一ORACLE的啟動和關閉

  在單機環境下要想啟動或關閉ORACLE系統必須首先切換到ORACLE用戶如下

  su oracle

  a啟動ORACLE系統

  oracle>svrmgrl

  SVRMGR>connect internal

  SVRMGR>startup

  SVRMGR>quit

  b關閉ORACLE系統

  oracle>svrmgrl

  SVRMGR>connect internal

  SVRMGR>shutdown

  SVRMGR>quit

  啟動oraclei數據庫命令

  $ sqlplus /nolog

  SQL*Plus: Release Production on Fri Oct ::

  Copyright (c) Oracle <; Corporation   All rights reserved

  SQL> connect / as sysdba

  Connected to an idle instance

  SQL> startup^C

  SQL> startup

  ORACLE instance started

  在雙機環境下要想啟動或關閉ORACLE系統必須首先切換到root用戶如下

  su - root

  a啟動ORACLE系統

  hareg -y oracle

  b關閉ORACLE系統

  hareg -n oracle

  Oracle <;數據庫有哪幾種啟動方式

  說明

  有以下幾種啟動方式

  startup nomount

  非安裝啟動這種方式啟動下可執行重建控制文件重建數據庫

  讀取initora文件啟動instance即啟動SGA和後台進程這種啟動只需要initora文件

  startup mount dbname

  安裝啟動這種方式啟動下可執行

  數據庫日志歸檔

  數據庫介質恢復

  使數據文件聯機或脫機

  重新定位數據文件重做日志文件

  執行nomount然後打開控制文件確認數據文件和聯機日志文件的位置

  但此時不對數據文件和日志文件進行校驗檢查

  startup open dbname

  先執行nomount然後執行mount再打開包括Redo log文件在內的所有數據庫文件

  這種方式下可訪問數據庫中的數據

  startup等於以下三個命令

  startup nomount

  alter database mount

  alter database open

  startup restrict

  約束方式啟動

  這種方式能夠啟動數據庫但只允許具有一定特權的用戶訪問

  非特權用戶訪問時會出現以下提示

  ERROR

  ORA: ORACLE 只允許具有 RESTRICTED SESSION 權限的用戶使用

  startup force

  強制啟動方式

  當不能關閉數據庫時可以用startup force來完成數據庫的關閉

  先關閉數據庫再執行正常啟動數據庫命令

  startup pfile=參數文件名

  帶初始化參數文件的啟動方式

  先讀取參數文件再按參數文件中的設置啟動數據庫

  例startup pfile=E:Oracleadminoradbpfileinitora

  startup EXCLUSIVE

  二用戶如何有效地利用數據字典

  ORACLE的數據字典是數據庫的重要組成部分之一它隨著數據庫的產生而產生 隨著數據庫的變化而變化

  體現為sys用戶下的一些表和視圖數據字典名稱是大寫的英文字符

  數據字典裡存有用戶信息用戶的權限信息所有數據對象信息表的約束條件統計分析數據庫的視圖等

  我們不能手工修改數據字典裡的信息

  很多時候一般的ORACLE用戶不知道如何有效地利用它

  dictionary   全部數據字典表的名稱和解釋它有一個同義詞dict

  dict_column   全部數據字典表裡字段名稱和解釋

  如果我們想查詢跟索引有關的數據字典時可以用下面這條SQL語句:

  SQL>select * from dictionary where instr(commentsindex)>;

  如果我們想知道user_indexes表各字段名稱的詳細含義可以用下面這條SQL語句:

  SQL>select column_namecomments from dict_columns where table_name=USER_INDEXES;

  依此類推就可以輕松知道數據字典的詳細名稱和解釋不用查看ORACLE的其它文檔資料了

  下面按類別列出一些ORACLE用戶常用數據字典的查詢使用方法

  用戶

  查看當前用戶的缺省表空間

  SQL>select usernamedefault_tablespace from user_users;

  查看當前用戶的角色

  SQL>select * from user_role_privs;

  查看當前用戶的系統權限和表級權限

  SQL>select * from user_sys_privs;

  SQL>select * from user_tab_privs;

  

  查看用戶下所有的表

  SQL>select * from user_tables;

  如果是按升序降序排列則為select * from user_tables order by id(其中的一項) desc/asc(升降序);

  查看名稱包含log字符的表

  SQL>select object_nameobject_id from user_objects

  where instr(object_nameLOG)>;

  查看某表的創建時間

  SQL>select object_namecreated from user_objects where object_name=upper(&table_name);

  查看某表的大小

  SQL>select sum(bytes)/(*) as size(M) from user_segments

  where segment_name=upper(&table_name);

  查看放在ORACLE的內存區裡的表

  SQL>select table_namecache from user_tables where instr(cacheY)>;

  索引

  查看索引個數和類別

  SQL>select index_nameindex_typetable_name from user_indexes order by table_name;

  查看索引被索引的字段

  SQL>select * from user_ind_columns where index_name=upper(&index_name);

  查看索引的大小

  SQL>select sum(bytes)/(*) as size(M) from user_segments

  where segment_name=upper(&index_name);

  序列號

  查看序列號last_number是當前值

  SQL>select * from user_sequences;

  視圖

  查看視圖的名稱

  SQL>select view_name from user_views;

  查看創建視圖的select語句

  SQL>set view_nametext_length from user_views;

  SQL>set long ; 說明可以根據視圖的text_length值設定set long 的大小

  SQL>select text from user_views where view_name=upper(&view_name);

  同義詞

  查看同義詞的名稱

  SQL>select * from user_synonyms;

  約束條件

  查看某表的約束條件

  SQL>select constraint_name constraint_typesearch_condition r_constraint_name

  from user_constraints where table_name = upper(&table_name);

  SQL>select nstraint_namenstraint_typelumn_name

  from user_constraints cuser_cons_columns cc

  where cowner = upper(&table_owner) and ctable_name = upper(&table_name)

  and cowner = ccowner and nstraint_name = nstraint_name

  order by ccposition;

  存儲 <;函數和過程

  查看函數和過程的狀態

  SQL>select object_namestatus from user_objects where object_type=FUNCTION;

  SQL>select object_namestatus from user_objects where object_type=PROCEDURE;

  查看函數和過程的源代碼

  SQL>select text from all_source where owner=user and name=upper(&plsql_name);

  三查看數據庫的SQL

  查看表空間的名稱及大小

  select ttablespace_name round(sum(bytes/(*))) ts_size

  from dba_tablespaces t dba_data_files d

  where ttablespace_name = dtablespace_name

  group by ttablespace_name;

  查看表空間物理文件的名稱及大小

  select tablespace_name file_id file_name

  round(bytes/(*)) total_space

  from dba_data_files

  order by tablespace_name;

  查看回滾段名稱及大小

  select segment_name tablespace_name rstatus

  (initial_extent/) InitialExtent(next_extent/) NextExtent

  max_extents vcurext CurExtent

  From dba_rollback_segs r v$rollstat v

  Where rsegment_id = vusn(+)

  order by segment_name ;

  查看控制文件

  select name from v$controlfile;

  查看日志文件

  select member from v$logfile;

  查看表空間的使用情況

  select sum(bytes)/(*) as free_spacetablespace_name

  from dba_free_space

  group by tablespace_name;

  SELECT ATABLESPACE_NAMEABYTES TOTALBBYTES USED CBYTES FREE

  (BBYTES*)/ABYTES % USED(CBYTES*)/ABYTES % FREE

  FROM SYSSM$TS_AVAIL ASYSSM$TS_USED BSYSSM$TS_FREE C

  WHERE ATABLESPACE_NAME=BTABLESPACE_NAME AND ATABLESPACE_NAME=CTABLESPACE_NAME;

  查看數據庫庫對象

  select owner object_type status count(*) count# from all_objects group by owner object_type status;

  查看數據庫的版本

  Select version FROM Product_component_version

  Where SUBSTR(PRODUCT)=Oracle;

  查看數據庫的創建日期和歸檔方式

  Select Created Log_Mode Log_Mode From V$Database;

  四ORACLE用戶連接的管理

  用系統管理員查看當前數據庫有幾個用戶連接

  SQL> select usernamesidserial# from v$session;

  如果要停某個連接用

  SQL> alter system kill session sidserial#;

  如果這命令不行找它UNIX的進程數

  SQL> select prospid from v$session sesv$process pro where sessid= and sespaddr=proaddr;

  說明是某個連接的sid數

  然後用 kill 命令殺此進程號

  五SQL*PLUS使用

  a近入SQL*Plus

  $sqlplus 用戶名/密碼

  退出SQL*Plus

  SQL>exit

  b在sqlplus下得到幫助信息

  列出全部SQL命令和SQL*Plus命令

  SQL>help

  列出某個特定的命令的信息

  SQL>help 命令名

  c顯示表結構命令DESCRIBE

  SQL>DESC 表名

  dSQL*Plus中的編輯命令

  顯示SQL緩沖區命令

  SQL>L

  修改SQL命令

  首先要將待改正行變為當前行

  SQL>n

  用CHANGE命令修改內容

  SQL>c/舊/新

  重新確認是否已正確

  SQL>L

  使用INPUT命令可以在SQL緩沖區中增加一行或多行

  SQL>i

  SQL>輸入內容

  e調用外部系統編輯器

  SQL>edit 文件名

  可以使用DEFINE命令設置系統變量EDITOR來改變文本編輯器的類型在loginsql文件中定義如下一行

  DEFINE_EDITOR=vi

  f運行命令文件

  SQL>START test

  SQL>@test

  常用SQL*Plus語句

  a表的創建修改刪除

  創建表的命令格式如下

  create table 表名 (列說明列表)

  為基表增加新列命令如下

  ALTER TABLE 表名 ADD (列說明列表)

  例為test表增加一列Age用來存放年齡

  sql>alter table test

  add (Age number())

  修改基表列定義命令如下

  ALTER TABLE 表名

  MODIFY (列名 數據類型)

  例將test表中的Count列寬度加長為個字符

  sql>alter atble test

  modify (County char())

  b將一張表刪除語句的格式如下

  DORP TABLE 表名

  例表刪除將同時刪除表的數據和表的定義

  sql>drop table test

  c表空間的創建刪除

  六ORACLE邏輯備份的SH文件

  完全備份的SH文件exp_compsh

  rq=` date +%m%d `

  su oracle c exp system/manager full=y inctype=complete file=/oracle/export/db_comp$rqdmp

  累計備份的SH文件exp_cumush

  rq=` date +%m%d `

  su oracle c exp system/manager full=y inctype=cumulative file=/oracle/export/db_cumu$rqdmp

  增量備份的SH文件: exp_incrsh

  rq=` date +%m%d `

  su oracle c exp system/manager full=y inctype=incremental file=/oracle/export/db_incr$rqdmp

  root用戶crontab文件

  /var/spool/cron/crontabs/root增加以下內容

   * * /oracle/exp_compsh

   * * /oracle/exp_incrsh

   * * /oracle/exp_cumush

  當然這個時間表可以根據不同的需求來改變的這只是一個例子

  七ORACLE 常用的SQL語法和數據對象

  一數據控制語句 (DML) 部分

  INSERT   (往數據表裡插入記錄的語句)

  INSERT INTO 表名(字段名 字段名 ……) VALUES ( 值 ……);

  INSERT INTO 表名(字段名 字段名 ……)   SELECT (字段名 字段名 ……) FROM 另外的表名;

  字符串類型的字段值必須用單引號括起來 例如: GOOD DAY

  如果字段值裡包含單引號 需要進行字符串轉換 我們把它替換成兩個單引號

  字符串類型的字段值超過定義的長度會出錯 最好在插入前進行長度校驗

  日期字段的字段值可以用當前數據庫的系統時間SYSDATE 精確到秒

  或者用字符串轉換成日期型函數TO_DATE(YYYYMMDD)

  TO_DATE()還有很多種日期格式 可以參看ORACLE DOC

  年日 小時:分鐘:秒 的格式YYYYMMDD HH:MI:SS

  INSERT時最大可操作的字符串長度小於等於個單字節 如果要插入更長的字符串 請考慮字段用CLOB類型

  方法借用ORACLE裡自帶的DBMS_LOB程序包

  INSERT時如果要用到從開始自動增長的序列號 應該先建立一個序列號

  CREATE SEQUENCE 序列號的名稱 (最好是表名+序列號標記) INCREMENT BY    START   WITH  

  MAXVALUE      CYCLE   NOCACHE;

  其中最大的值按字段的長度來定 如果定義的自動增長的序列號 NUMBER() 最大值為

  INSERT 語句插入這個字段值為: 序列號的名稱NEXTVAL

  DELETE   (刪除數據表裡記錄的語句)

  DELETE FROM表名 WHERE 條件;

  注意刪除記錄並不能釋放ORACLE裡被占用的數據塊表空間 它只把那些被刪除的數據塊標成unused

  如果確實要刪除一個大表裡的全部記錄 可以用 TRUNCATE 命令 它可以釋放占用的數據塊表空間

  TRUNCATE TABLE 表名;

  此操作不可回退

  UPDATE   (修改數據表裡記錄的語句)

  UPDATE表名 SET 字段名=值 字段名=值 …… WHERE 條件;

  如果修改的值N沒有賦值或定義時 將把原來的記錄內容清為NULL 最好在修改前進行非空校驗;

  值N超過定義的長度會出錯 最好在插入前進行長度校驗

  注意事項:

  A 以上SQL語句對表都加上了行級鎖

  確認完成後 必須加上事物處理結束的命令 COMMIT 才能正式生效

  否則改變不一定寫入數據庫裡

  如果想撤回這些操作 可以用命令 ROLLBACK 復原

  B 在運行INSERT DELETE 和 UPDATE 語句前最好估算一下可能操作的記錄范圍

  應該把它限定在較小 (一萬條記錄) 范圍內 否則ORACLE處理這個事物用到很大的回退段

  程序響應慢甚至失去響應 如果記錄數上十萬以上這些操作 可以把這些SQL語句分段分次完成

  其間加上COMMIT 確認事物處理

  二數據定義 (DDL) 部分

  CREATE (創建表 索引 視圖 同義詞 過程 函數 數據庫鏈接等)

  ORACLE常用的字段類型有

  CHAR 固定長度的字符串

  VARCHAR 可變長度的字符串

  NUMBER(MN) 數字型M是位數總長度 N是小數的長度

  DATE 日期類型

  創建表時要把較小的不為空的字段放在前面 可能為空的字段放在後面

  創建表時可以用中文的字段名 但最好還是用英文的字段名

  創建表時可以給字段加上默認值 例如 DEFAULT SYSDATE

  這樣每次插入和修改時 不用程序操作這個字段都能得到動作的時間

  創建表時可以給字段加上約束條件

  例如 不允許重復 UNIQUE 關鍵字 PRIMARY KEY

  ALTER (改變表 索引 視圖等)

  改變表的名稱

  ALTER TABLE 表名   TO 表名;

  在表的後面增加一個字段

  ALTER TABLE表名 ADD 字段名 字段名描述;

  修改表裡字段的定義描述

  ALTER TABLE表名 MODIFY字段名 字段名描述;

  給表裡的字段加上約束條件

  ALTER TABLE 表名 ADD CONSTRAINT 約束名 PRIMARY KEY (字段名);

  ALTER TABLE 表名 ADD CONSTRAINT 約束名 UNIQUE (字段名);

  把表放在或取出數據庫的內存區

  ALTER TABLE 表名 CACHE;

  ALTER TABLE 表名 NOCACHE;

  DROP (刪除表 索引 視圖 同義詞 過程 函數 數據庫鏈接等)

  刪除表和它所有的約束條件

  DROP TABLE 表名 CASCADE CONSTRAINTS;

  TRUNCATE (清空表裡的所有記錄 保留表的結構)

  TRUNCATE 表名;

  三查詢語句 (SELECT) 部分

  SELECT字段名 字段名 …… FROM 表名 [表名 ……] WHERE 條件;

  字段名可以帶入函數

  例如:   COUNT(*) MIN(字段名)   MAX(字段名)   AVG(字段名) DISTINCT(字段名)

  TO_CHAR(DATE字段名YYYYMMDD HH:MI:SS)

  NVL(EXPR EXPR)函數

  解釋:

  IF EXPR=NULL

  RETURN EXPR

  ELSE

  RETURN EXPR

  DECODE(AA﹐V﹐R﹐V﹐R)函數

  解釋:

  IF AA=V THEN RETURN R

  IF AA=V THEN RETURN R

  

  ELSE

  RETURN NULL

  LPAD(charnchar)函數

  解釋:

  字符char按制定的位數n顯示不足的位數用char字符串替換左邊的空位

  字段名之間可以進行算術運算

  例如:   (字段名*字段名)/

  查詢語句可以嵌套

  例如: SELECT …… FROM

  (SELECT …… FROM表名 [表名 ……] WHERE 條件) WHERE 條件;

  兩個查詢語句的結果可以做集合操作

  例如: 並集UNION(去掉重復記錄) 並集UNION ALL(不去掉重復記錄) 差集MINUS   交集INTERSECT

  分組查詢

  SELECT字段名 字段名 …… FROM 表名 [表名 ……] GROUP BY字段名

  [HAVING 條件] ;

  兩個以上表之間的連接查詢

  SELECT字段名 字段名 …… FROM 表名 [表名 ……] WHERE

  表名字段名 = 表名 字段名 [ AND ……] ;

  SELECT字段名 字段名 …… FROM 表名 [表名 ……] WHERE

  表名字段名 = 表名 字段名(+) [ AND ……] ;

  有(+)號的字段位置自動補空值

  查詢結果集的排序操作 默認的排序是升序ASC 降序是DESC

  SELECT字段名 字段名 …… FROM 表名 [表名 ……]

  ORDER BY字段名 字段名 DESC;

  字符串模糊比較的方法

  INSTR(字段名 字符串)>

  字段名 LIKE   字符串%   [%字符串%]

  每個表都有一個隱含的字段ROWID 它標記著記錄的唯一性

  四ORACLE裡常用的數據對象 (SCHEMA)

  索引 (INDEX)

  CREATE INDEX 索引名ON 表名 ( 字段 [字段 ……] );

  ALTER INDEX 索引名 REBUILD;

  一個表的索引最好不要超過三個 (特殊的大表除外) 最好用單字段索引 結合SQL語句的分析執行情況

  也可以建立多字段的組合索引和基於函數的索引

  ORACLE字符串可以索引的最大長度為 單字節

  ORACLE字符串可以索引的最大長度為 單字節

  視圖 (VIEW)

  CREATE VIEW 視圖名AS SELECT … FROM …;

  ALTER VIEW視圖名 COMPILE;

  視圖僅是一個SQL查詢語句 它可以把表之間復雜的關系簡潔化

  同義詞 (SYNONMY)

  CREATE SYNONYM同義詞名FOR 表名;

  CREATE SYNONYM同義詞名FOR 表名@數據庫鏈接名;

  數據庫鏈接 (DATABASE LINK)

  CREATE DATABASE LINK數據庫鏈接名CONNECT TO 用戶名 IDENTIFIED BY 密碼 USING 數據庫連接字符串;

  數據庫連接字符串可以用NET EASY CONFIG或者直接修改TNSNAMESORA裡定義

  數據庫參數global_name=true時要求數據庫鏈接名稱跟遠端數據庫名稱一樣

  數據庫全局名稱可以用以下命令查出

  SELECT * FROM GLOBAL_NAME;

  查詢遠端數據庫裡的表

  SELECT …… FROM 表名@數據庫鏈接名;

  五權限管理 (DCL) 語句

  GRANT 賦於權限

  常用的系統權限集合有以下三個:

  CONNECT(基本的連接) RESOURCE(程序開發) DBA(數據庫管理)

  常用的數據對象權限有以下五個:

  ALL ON 數據對象名 SELECT ON 數據對象名 UPDATE ON 數據對象名

  DELETE ON 數據對象名   INSERT ON 數據對象名 ALTER   ON 數據對象名

  GRANT CONNECT RESOURCE TO 用戶名;

  GRANT SELECT ON 表名 TO 用戶名;

  GRANT SELECT INSERT DELETE ON表名 TO 用戶名 用戶名;

  REVOKE 回收權限

  REVOKE CONNECT RESOURCE FROM 用戶名;

  REVOKE SELECT ON 表名 FROM 用戶名;

  REVOKE SELECT INSERT DELETE ON表名 FROM 用戶名 用戶名;

  查詢數據庫中第號錯誤

  select orgaddrdestaddr from sm_histable where error_code=;

  查詢數據庫中開戶用戶最大提交和最大下發數 select MSISDNTCOSOCOS from ms_usertable

  查詢數據庫中各種錯誤代碼的總和

  select error_codecount(*) from sm_histable group by error_code order

  by error_code;

  查詢報表數據庫中話單統計種類查詢

  select sum(Successcount) from tbl_MiddleMt where ServiceType=

  select sum(successcount)servicetype from tbl_middlemt group by servicetype

  另外當建的表中出現好多重復數據時可進行相應的刪除操作如下所示

  刪除重復行有兩種方法

  數據准備

  建表語句

  create table a(a varchar()b varchar());

  插入數據

  insert into a values();

  insert into a values();

  insert into a values();

  insert into a values(aabb);

  insert into a values(aabb);

  insert into a values(ccdd);

  commit;

  克隆一張表

  create table test  as (select * from a);

  查詢()select * from test

  

  

  

   aa bb

   aa bb

   cc dd

  ()

  select distinct * from test;

  

   cc dd

   aa bb

  )利用中間表法create table test_copy as (select distinct * from test);

  然後刪除原表 drop table test;

  create table test as (select  * from test_copy);

  然後就完成了

  )利用rowid法

  sql語句如下:

  delete from test t where rowid not in(

  select max(rowid) from test p  where ta=pa and tb=pb);

  commit;


From:http://tw.wingwit.com/Article/program/Oracle/201311/16708.html
    推薦文章
    Copyright © 2005-2022 電腦知識網 Computer Knowledge   All rights reserved.