1. 程式人生 > >Oracle常用語句

Oracle常用語句

max dia ORC dmp文件 我不 dex ignore 添加 bms

================常用命令=============================
一、Oracle可以使用自帶的sqlplus(點擊“開始”,搜索“sqlplus”)打開,也可以使用cmd窗口命令符。
1、使用自帶的sqlplus輸入命令:
sqlplus /as sysdba (無需密碼)
2、使用cmd打開
1.sqlplus /nolog
2.conn sys/口令 as sysdba(連接身份)

二、創建用戶
CREATE USER 用戶名 IDENTIFIED BY 口令 [ACCOUNT LOCK | UNLOCK] (默認是LOCK,一般設置為UNLOCK)
創建完用戶還不能登錄,需要授權。(權限:就是若幹個數據庫角色的集合)
三、授權
grant 權限 to 用戶名;
權限分三種:
DBA: 擁有全部特權,是系統最高權限,只有DBA才可以創建數據庫結構。一般自己建的數據庫直接授權DBA後就不用授權後兩個了。
RESOURCE:擁有Resource權限的用戶只可以創建實體,不可以創建數據庫結構。
CONNECT:擁有Connect權限的用戶只可以登錄Oracle,不可以創建實體,不可以創建數據庫結構。
四、撤銷授權
revoke 權限 from 用戶名;

=========================刪除用戶======================
drop user 用戶名 cascade;


===========================創建表空間================================
create bigfile tablespace bxfund
datafile ‘D:\Ysszx\bxfund.dbf‘ size 50g
autoextend on next 50M maxsize unlimited logging
extent management local autoallocate
segment space management auto;


============創建臨時表空間 如果建超大空間,需要在前面添加bigfile==============
create bigfile temporary tablespace bxfund_temp
tempfile ‘E:\RbWork\tablenamespace\bxfund_temp.dbf‘
size 80g
autoextend on next 50m
extent management local


=================創建用戶並指定表空間===========================
create user piccfund identified by piccfund
default tablespace bxfund
tablespace finchinafcdd;

=========================dmp文件導入數據庫======================
在cmd下用 imp導入 格式: imp userName/passWord file=bmp文件路徑 ignore = y (忽略創建錯誤)full=y(導入文件中全部內容);

imp PICCFUND/PICCFUND file="全路徑" ignore=y full=y;

eg:
imp piccreport/piccreport file=F:\外出開會\piccreport20180326.dmp ignore=y full=y;

=======================導出dmp文件============================


數據導出:

exp 用戶名/密碼@網絡服務名 file=xxx.dmp tables=(表名);

eg:
exp user/[email protected] file=d:\dbbackup\file1221_zwy.dmp log=d:\dbbackup\file1221_zwy.log


exp user/"""123@456"""@10.83.200.171 file=d:\dbbackup\file1221_zwy.dmp log=d:\dbbackup\file1221_zwy.log


註:數據庫密碼中含有@字符時,用"""區分。

1 將數據庫TEST完全導出,用戶名system 密碼manager 導出到D:\daochu.dmp中

exp rmdb/rmdb123@hz_rmdb file=d:\daochu.dmp full=y

2 將數據庫中system用戶與sys用戶的表導出

exp rmdb/rmdb123@hz_rmdb file=d:\daochu.dmp owner=(system,sys)

3 將數據庫中的表table1 、table2導出

exp rmdb/rmdb123@hz_rmdb file=d:\daochu.dmp tables=(table1,table2)

4 將數據庫中的表table1中的字段filed1以"00"打頭的數據導出

exp rmdb/rmdb123@hz_rmdb file=d:\daochu.dmp tables=(table1) query=\" where filed1 like ‘00%‘\"

上面是常用的導出,對於壓縮我不太在意,用winzip把dmp文件可以很好的壓縮。
不過在上面命令後面 加上 compress=y 就可以了

================查看表空間使用情況===================
SELECT a.tablespace_name "表空間名",
total "表空間大小",
free "表空間剩余大小",
(total - free) "表空間使用大小",
total / (1024 * 1024 * 1024) "表空間大小(G)",
free / (1024 * 1024 * 1024) "表空間剩余大小(G)",
(total - free) / (1024 * 1024 * 1024) "表空間使用大小(G)",
round((total - free) / total, 4) * 100 "使用率 %"
FROM (SELECT tablespace_name, SUM(bytes) free
FROM dba_free_space
GROUP BY tablespace_name) a,
(SELECT tablespace_name, SUM(bytes) total
FROM dba_data_files
GROUP BY tablespace_name) b
WHERE a.tablespace_name = b.tablespace_name;

=========================查看用戶屬於哪個表空間======================
select username,default_tablespace from dba_users where username=‘用戶名‘;

eg:
select username,default_tablespace from dba_users where username=‘SCOTT‘;--用戶名需要大寫

--統計當前數據庫表及數據量
select u.TABLE_NAME,u.NUM_ROWS from user_tables u
where table_name in(‘CSJJXX‘,‘JJHZXX‘,‘CSZQXX‘)


--強制走索引
select /*+index(t index_name)*/ * from xxx t;

--重啟數據庫
sqlplus ....
shutdown immediate ;
startup;


---表碎片整理
--https://blog.csdn.net/ggwxk1990/article/details/77867748
alter table lusers enable row movement ;

ALTER TABLE lusers SHRINK SPACE COMPACT

ALTER TABLE lusers SHRINK SPACE cascade;

--
SELECT tablespace_name,
file_id,
file_name,
round(bytes / (1024 * 1024), 0) total_space
FROM dba_data_files
ORDER BY tablespace_name;

## 利用視圖查看
select name from v$datafile;

--表空間使用情況查詢
SELECT UPPER(F.TABLESPACE_NAME) "表空間名",
  D.TOT_GROOTTE_MB "表空間大小(M)",
  D.TOT_GROOTTE_MB - F.TOTAL_BYTES "已使用空間(M)",
  TO_CHAR(ROUND((D.TOT_GROOTTE_MB - F.TOTAL_BYTES) / D.TOT_GROOTTE_MB * 100,2),‘990.99‘) || ‘%‘ "使用比",
  F.TOTAL_BYTES "空閑空間(M)",
  F.MAX_BYTES "最大塊(M)"
  FROM (SELECT TABLESPACE_NAME,
  ROUND(SUM(BYTES) / (1024 * 1024), 2) TOTAL_BYTES,
  ROUND(MAX(BYTES) / (1024 * 1024), 2) MAX_BYTES
  FROM SYS.DBA_FREE_SPACE
  GROUP BY TABLESPACE_NAME) F,
  (SELECT DD.TABLESPACE_NAME,
   ROUND(SUM(DD.BYTES) / (1024 * 1024), 2) TOT_GROOTTE_MB
  FROM SYS.DBA_DATA_FILES DD
  GROUP BY DD.TABLESPACE_NAME) D
  WHERE D.TABLESPACE_NAME = F.TABLESPACE_NAME
  ORDER BY 1;

---------------------------------
--增加表空間文件
ALTER TABLESPACE app_data ADD DATAFILE
‘D:\ORACLE\PRODUCT\10.2.0\ORADATA\EDWTEST\APP03.DBF‘ SIZE 50M;

--手工改變已存在數據文件的大小
ALTER DATABASE DATAFILE ‘D:\ORACLE\PRODUCT\10.2.0\ORADATA\EDWTEST\APP02.DBF‘
RESIZE 100M;
---------------------------------
SQL code
--刪除空的表空間,但是不包含物理文件
drop tablespace tablespace_name;
--刪除非空表空間,但是不包含物理文件
drop tablespace tablespace_name including contents;
--刪除空表空間,包含物理文件
drop tablespace tablespace_name including contents and datafiles;
--刪除非空表空間,包含物理文件
drop tablespace tablespace_name including contents and datafiles;
--如果其他表空間中的表有外鍵等約束關聯到了本表空間中的表的字段,就要加上CASCADE CONSTRAINTS
drop tablespace tablespace_name including contents and datafiles CASCADE CONSTRAINTS;

--創建表空間
CREATE TABLESPACE report_bxfund LOGGING DATAFILE ‘/home/oracle/app/oracle/oradata/orcl/report_bxfund.dbf‘ SIZE 20480M AUTOEXTEND ON NEXT 128M EXTENT MANAGEMENT LOCAL;

--創建臨時表空間
create temporary tablespace report_bxfund_temp tempfile ‘/home/oracle/app/oracle/oradata/orcl/report_bxfund_temp.dbf‘ size 1024m autoextend on next 32m extent management local;

--創建用戶
CREATE USER report_bxfund IDENTIFIED BY report_bxfund DEFAULT TABLESPACE report_bxfund TEMPORARY TABLESPACE report_bxfund_temp;

--授權
grant connect,resource,dba to report_bxfund;

grant create session to report_bxfund;


--## 利用視圖查看
select name from v$datafile;

----獲得創建表空間的語句:*/

SELECT dbms_metadata.get_ddl(‘TABLESPACE‘,‘SYSTEM‘) FROM dual;

---- 添加 表空間的語句:*/

ALTER TABLESPACE report_bxfund ADD DATAFILE ‘/home/oracle/app/oracle/oradata/orcl/report_bxfund2.dbf‘ SIZE 20480M AUTOEXTEND ON NEXT 128M MAXSIZE UNLIMITED;


---刪除用戶 刪除表空間--------------------------------------
drop tablespace zhjjetf including contents and datafiles cascade constraint;

drop user zhjjetf cascade;

--- 權限訪問表空間 不受限
alter user GUARD4ABC quota unlimited on JK4ABC

--- 修改用戶密碼
alter user <username> identified by xxxx

Oracle常用語句