oracle often commands

仍是這個好用java

 

 

  Oracle mysql
對比版本 Personal Oracle7 Release 7.3.4.0.0 mysql 3.23.58-nt
啓動畫面
(點擊放大)
默認安裝目錄 C:ORAWIN95 F:MySQL
各類實用程序所在目錄 C:ORAWIN95BIN F:MySQLBIN
控制檯工具 SVRMGR.EXE
SVRMGR23.EXE
mysqladmin.exe
數據庫啓動程序 0start73.exe screen mysqld-shareware.exe
關閉數據庫命令 ostop73.exe mysqladmin.exe -u root shutdown
客戶程序 SQL*Plus mysql
啓動命令 c:orawin95binsqlplus.exe F:MySQLbinmysql.exe
帶用戶啓動方式
(直接連庫方式)
c:orawin95binsqlplus.exe system/manager@TNS F:MySQLbinmysql.exe test
F:MySQLbinmysql.exe -u root test
安裝後系統默認用戶(庫) sys
system
scott
mysql
test
顯示全部用戶(庫) SQL >select * from all_users; F:MySQLbin>mysqlshow
F:MySQLbin>mysqlshow --status
mysql> show databases;
退出命令 SQL> exit
SQL> quit
mysql> exit
mysql> quit
改變鏈接用戶(庫) SQL> conn 用戶名/密碼@主機字符串 mysql> use 庫名
查詢當前全部的表 SQL> select * from tab;
SQL> select * from cat;
mysql> show tables;
F:MySQLbin>mysqlshow 庫名
顯示當前鏈接用戶(庫) SQL> show user mysql> connect
查看幫助 SQL> ? mysql> help
顯示錶結構 SQL> desc 表名
SQL> describe 表名
mysql> desc 表名;
mysql> describe 表名;
mysql> show columns from 表名;
F:MySQLbin>mysqlshow 庫名 表名
日期函數 SQL> select sysdate from dual; mysql> select now();
mysql> select sysdate();
mysql> select curdate();
mysql> select current_date;
mysql> select curtime();
mysql> select current_time;
日期格式化 SQL> select to_char(sysdate,'yyyy-mm-dd') from dual;
SQL> select to_char(sysdate,'hh24-mi-ss') from dual;
mysql> select date_format(now(),'%Y-%m-%d');
mysql> select time_format(now(),'%H-%i-%S');
日期函數
(增長一個月)
SQL> select to_char(add_months(to_date('20000101','yyyymmdd'),1),'yyyy-mm-dd') from dual;
結果:2000-02-01
SQL> select to_char(add_months(to_date('20000101','yyyymmdd'),5),'yyyy-mm-dd') from dual;
結果:2000-06-01
mysql> select date_add('2000-01-01',interval 1 month);
結果:2000-02-01
mysql> select date_add('2000-01-01',interval 5 month);
結果:2000-06-01
別名 SQL> select 1 a from dual; mysql> select 1 as a;
字符串截取函數 SQL> select substr('abcdefg',1,5) from dual;
SQL> select substrb('abcdefg',1,5) from dual;
結果:abcde
mysql> select substring('abcdefg',2,3);
結果:bcd
mysql> select mid('abcdefg',2,3);
結果:bcd
mysql> select substring('abcdefg',2);
結果:bcdefg
mysql> select substring('abcdefg' from 2);
結果:bcdefg
另有SUBSTRING_INDEX(str,delim,count)函數
返回從字符串str的第count個出現的分隔符delim以後的子串。
若是count是正數,返回最後的分隔符到左邊(從左邊數) 的全部字符。
若是count是負數,返回最後的分隔符到右邊的全部字符(從右邊數)。
執行外部腳本命令 SQL >@a.sql 1:mysql> source a.sql
2:F:MySQLbin>mysql 3:F:MySQLbin>mysql 庫名
導入、導出工具 exp.exe
exp73.exe
imp.exe
imp73.exe
mysqldump.exe
mysqlimport.exe
改表名 SQL> rename a to b; mysql> alter table a rename b;
執行命令 ;<回車>
/
r
run
;<回車>
go
ego
distinct用法 SQL> select distinct 列1 from 表1;
SQL> select distinct 列1,列2 from 表1;
mysql> select distinct 列1 from 表1;
mysql> select distinct 列1,列2 from 表1;
註釋 --
/*與*/
#
--
/*與*/
看成計算器 SQL> select 1+1 from dual; mysql> select 1+1;
限制返回記錄條數 SQL> select * from 表名 where rownum<5; mysql> select * from 表名 limit 5;
新建用戶(庫) SQL> create user 用戶名 identified by 密碼; mysql> create database 庫名;
刪用戶(庫) SQL> drop user 用戶名; mysql> drop database 庫名;
外鏈接 使用(+) 使用left join
查詢索引 SQL> select index_name,table_name from user_indexes; mysql> show index from 表名 [FROM 庫名];
通配符 「%」 「%」和「_」
SQL語法 SELECT selection_list 選擇哪些列
FROM table_list 從何處選擇行
WHERE primary_constraint 行必須知足什麼條件
GROUP BY grouping_columns 怎樣對結果分組
HAVING secondary_constraint 行必須知足的第二條件
ORDER BY sorting_columns 怎樣對結果排序
SELECT selection_list 選擇哪些列
FROM table_list 從何處選擇行
WHERE primary_constraint 行必須知足什麼條件
GROUP BY grouping_columns 怎樣對結果分組
HAVING secondary_constraint 行必須知足的第二條件
ORDER BY sorting_columns 怎樣對結果排序
LIMIT count 結果限定

 

 

 

——————————————————————————————————————————————————mysql

詳細版本sql

1、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

 

啓動oracle9i數據庫命令:
$ 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.

 

二、在雙機環境下要想啓動或關閉ORACLE系統必須首先切換到root用戶,以下
su - root

 

a、啓動ORACLE系統
hareg -y oracle

 

b、關閉ORACLE系統
hareg -n oracle

 

Oracle數據庫有哪幾種啓動方式

 

說明:

 

有如下幾種啓動方式:
一、startup nomount
非安裝啓動,這種方式啓動下可執行:重建控制文件、重建數據庫
讀取init.ora文件,啓動instance,即啓動SGA和後臺進程,這種啓動只須要init.ora文件。

 

二、startup mount dbname
安裝啓動,這種方式啓動下可執行:
數據庫日誌歸檔、
數據庫介質恢復、
使數據文件聯機或脫機,
從新定位數據文件、重作日誌文件。

 

執行「nomount」,而後打開控制文件,確認數據文件和聯機日誌文件的位置,
但此時不對數據文件和日誌文件進行校驗檢查。

 

三、startup open dbname
先執行「nomount」,而後執行「mount」,再打開包括Redo log文件在內的全部數據庫文件,
這種方式下可訪問數據庫中的數據。

 

四、startup,等於如下三個命令
startup nomount
alter database mount
alter database open

 

五、startup restrict
約束方式啓動
這種方式可以啓動數據庫,但只容許具備必定特權的用戶訪問
非特權用戶訪問時,會出現如下提示:
ERROR:
ORA-01035: ORACLE 只容許具備 RESTRICTED SESSION 權限的用戶使用

 

六、startup force
強制啓動方式 bitsCN.com中國網管聯盟 
當不能關閉數據庫時,能夠用startup force來完成數據庫的關閉
先關閉數據庫,再執行正常啓動數據庫命令

 

七、startup pfile=參數文件名
帶初始化參數文件的啓動方式
先讀取參數文件,再按參數文件中的設置啓動數據庫
例:startup pfile=E:Oracleadminoradbpfileinit.ora

 

八、startup EXCLUSIVE
2、用戶如何有效地利用數據字典
 ORACLE的數據字典是數據庫的重要組成部分之一,它隨着數據庫的產生而產生, 隨着數據庫的變化而變化,體現爲sys用戶下的一些表和視圖。數據字典名稱是大寫的英文字符。
    數據字典裏存有用戶信息、用戶的權限信息、全部數據對象信息、表的約束條件、統計分析數據庫的視圖等。
  咱們不能手工修改數據字典裏的信息。
  不少時候,通常的ORACLE用戶不知道如何有效地利用它。

 

 dictionary   所有數據字典表的名稱和解釋,它有一個同義詞dict
    dict_column   所有數據字典表裏字段名稱和解釋

 

    若是咱們想查詢跟索引有關的數據字典時,能夠用下面這條SQL語句:

 

    SQL>select * from dictionary where instr(comments,'index')>0;

 

    若是咱們想知道user_indexes表各字段名稱的詳細含義,能夠用下面這條SQL語句:

 

    SQL>select column_name,comments from dict_columns where 
table_name='USER_INDEXES';

 

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

 

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

 

    一、用戶
        查看當前用戶的缺省表空間
        SQL>select username,default_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;

 

            查看名稱包含log字符的表
            SQL>select object_name,object_id from user_objects 
                where instr(object_name,'LOG')>0;

 

            查看某表的建立時間
            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的內存區裏的表
            SQL>select table_name,cache from user_tables where 
instr(cache,'Y')>0;

 

    三、索引
            查看索引個數和類別
            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');

 

    四、序列號
            查看序列號,last_number是當前值
            SQL>select * from user_sequences;

 

    五、視圖
            查看視圖的名稱
            SQL>select view_name from user_views;

 

            查看建立視圖的select語句
            SQL>set view_name,text_length from user_views; 
            SQL>set long 2000;                
說明:能夠根據視圖的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_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;

 

    八、存儲函數和過程
            查看函數和過程的狀態
            SQL>select object_name,status from user_objects where 
object_type='FUNCTION';
            SQL>select object_name,status from user_objects where 
object_type='PROCEDURE';

 

            查看函數和過程的源代碼
            SQL>select text from all_source where owner=user and 
name=upper('&plsql_name');

 

3、查看數據庫的SQL
一、查看錶空間的名稱及大小
    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;

 

二、查看錶空間物理文件的名稱及大小
    select tablespace_name, file_id, file_name,
    round(bytes/(1024*1024),0) total_space
    from dba_data_files
    order by tablespace_name;

 

三、查看回滾段名稱及大小
    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 ;

 

四、查看控制文件
    select name from v$controlfile;

 

五、查看日誌文件
    select member from v$logfile;

 

六、查看錶空間的使用狀況
    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;

 

七、查看數據庫庫對象
    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,1,6)='Oracle';

 

九、查看數據庫的建立日期和歸檔方式
  Select Created, Log_Mode, Log_Mode From V$Database;
  
4、ORACLE用戶鏈接的管理
用系統管理員,查看當前數據庫有幾個用戶鏈接:
SQL> select username,sid,serial# from v$session;
若是要停某個鏈接用
SQL> alter system kill session 'sid,serial#';

 

若是這命令不行,找它UNIX的進程數
SQL> select pro.spid from v$session ses,v$process pro where 
ses.sid=21 and ses.paddr=pro.addr;

 

說明:21是某個鏈接的sid數

 

而後用 kill 命令殺此進程號。
5、SQL*PLUS使用 
a、近入SQL*Plus
$sqlplus 用戶名/密碼

 

   退出SQL*Plus
SQL>exit

 

b、在sqlplus下獲得幫助信息
列出所有SQL命令和SQL*Plus命令
SQL>help
列出某個特定的命令的信息
SQL>help 命令名

 

c、顯示錶結構命令DESCRIBE
SQL>DESC 表名

 

d、SQL*Plus中的編輯命令
顯示SQL緩衝區命令
SQL>L

 

修改SQL命令
首先要將待改正行變爲當前行
SQL>n
用CHANGE命令修改內容
SQL>c/舊/新
從新確認是否已正確
SQL>L

 

使用INPUT命令能夠在SQL緩衝區中增長一行或多行
SQL>i
SQL>輸入內容

 

e、調用外部系統編輯器

 

SQL>edit 文件名
可使用DEFINE命令設置系統變量EDITOR來改變文本編輯器的類型,在login.sql文件中定義以下一行
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(3));

 

修改基表列定義命令以下:
ALTER TABLE 表名
MODIFY (列名 數據類型)
例:將test表中的Count列寬度加長爲10個字符
    sql>alter atble test
        modify (County char(10));

 

b、將一張表刪除語句的格式以下:
DORP TABLE 表名;
例:表刪除將同時刪除表的數據和表的定義
sql>drop table test

 

c、表空間的建立、刪除

 

6、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"

 

累計備份的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增長如下內容

 

0 2 1 * * /oracle/exp_comp.sh

 

30 2 * * 0-5 /oracle/exp_incr.sh

 

45 2 * * 6 /oracle/exp_cumu.sh

 

固然這個時間表能夠根據不一樣的需求來改變的,這只是一個例子。

 

7、ORACLE 經常使用的SQL語法和數據對象
一.數據控制語句 (DML) 部分
1.INSERT (往數據表裏插入記錄的語句)

 

INSERT INTO 表名(字段名1, 字段名2, ……) VALUES ( 值1, 值2, ……); 
INSERT INTO 表名(字段名1, 字段名2, ……) SELECT (字段名1, 字段名2, ……) FROM 另外的表名;

 

字符串類型的字段值必須用單引號括起來, 例如: ’GOOD DAY’
若是字段值裏包含單引號’ 須要進行字符串轉換, 咱們把它替換成兩個單引號''.
字符串類型的字段值超過定義的長度會出錯, 最好在插入前進行長度校驗.

 

日期字段的字段值能夠用當前數據庫的系統時間SYSDATE, 精確到秒
或者用字符串轉換成日期型函數TO_DATE(‘2001-08-01’,’YYYY-MM-DD’)
TO_DATE()還有不少種日期格式, 能夠參看ORACLE DOC.
年-月-日 小時:分鐘:秒 的格式YYYY-MM-DD HH24:MI:SS

 

INSERT時最大可操做的字符串長度小於等於4000個單字節, 若是要插入更長的字符串, 請考慮字段用CLOB類型,
方法借用ORACLE裏自帶的DBMS_LOB程序包.

 

INSERT時若是要用到從1開始自動增加的序列號, 應該先創建一個序列號
CREATE SEQUENCE 序列號的名稱 (最好是表名+序列號標記) INCREMENT BY 1 START WITH 1
MAXVALUE 99999 CYCLE NOCACHE;
其中最大的值按字段的長度來定, 若是定義的自動增加的序列號 NUMBER(6) , 最大值爲999999

 

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

 

2.DELETE (刪除數據表裏記錄的語句)

 

DELETE FROM表名 WHERE 條件;

 

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

 

若是確實要刪除一個大表裏的所有記錄, 能夠用 TRUNCATE 命令, 它能夠釋放佔用的數據塊表空間
TRUNCATE TABLE 表名;
此操做不可回退.

 

3.UPDATE (修改數據表裏記錄的語句)

 

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

 

若是修改的值N沒有賦值或定義時, 將把原來的記錄內容清爲NULL, 最好在修改前進行非空校驗;
值N超過定義的長度會出錯, 最好在插入前進行長度校驗..

 

注意事項:
A.        以上SQL語句對錶都加上了行級鎖,
        確認完成後, 必須加上事物處理結束的命令 COMMIT 才能正式生效,
        不然改變不必定寫入數據庫裏.
        若是想撤回這些操做, 能夠用命令 ROLLBACK 復原.

 

B.        在運行INSERT, DELETE 和 UPDATE 語句前最好估算一下可能操做的記錄範圍, 
        應該把它限定在較小 (一萬條記錄) 範圍內,. 不然ORACLE處理這個事物用到很大的回退段.
        程序響應慢甚至失去響應. 若是記錄數上十萬以上這些操做, 能夠把這些SQL語句分段分次完成,
        其間加上COMMIT 確認事物處理.
二.數據定義 (DDL) 部分
1.CREATE (建立表, 索引, 視圖, 同義詞, 過程, 函數, 數據庫連接等)

 

ORACLE經常使用的字段類型有
CHAR                        固定長度的字符串
VARCHAR2                可變長度的字符串
NUMBER(M,N)                數字型M是位數總長度, N是小數的長度
DATE                        日期類型
建立表時要把較小的不爲空的字段放在前面, 可能爲空的字段放在後面
建立表時能夠用中文的字段名, 但最好仍是用英文的字段名
建立表時能夠給字段加上默認值, 例如 DEFAULT SYSDATE 
這樣每次插入和修改時, 不用程序操做這個字段都能獲得動做的時間
建立表時能夠給字段加上約束條件
例如 不容許重複 UNIQUE, 關鍵字 PRIMARY KEY

 

2.ALTER        (改變表, 索引, 視圖等)

 

改變表的名稱
ALTER TABLE 表名1 TO 表名2;
在表的後面增長一個字段
ALTER TABLE表名 ADD 字段名 字段名描述;

 

修改表裏字段的定義描述
ALTER TABLE表名 MODIFY字段名 字段名描述;

 

給表裏的字段加上約束條件
ALTER TABLE 表名 ADD CONSTRAINT 約束名 PRIMARY KEY (字段名);
ALTER TABLE 表名 ADD CONSTRAINT 約束名 UNIQUE (字段名);

 

把表放在或取出數據庫的內存區
ALTER TABLE 表名 CACHE;
ALTER TABLE 表名 NOCACHE;

 

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

 

刪除表和它全部的約束條件
DROP TABLE 表名 CASCADE CONSTRAINTS;

 

4.TRUNCATE (清空表裏的全部記錄, 保留表的結構)

 

TRUNCATE 表名;

 

三.查詢語句 (SELECT) 部分
SELECT字段名1, 字段名2, …… FROM 表名1, [表名2, ……] WHERE 條件;

 

字段名能夠帶入函數
例如: COUNT(*), MIN(字段名), MAX(字段名), AVG(字段名), DISTINCT(字段名),
           TO_CHAR(DATE字段名,'YYYY-MM-DD HH24:MI:SS')

 

NVL(EXPR1, EXPR2)函數
解釋:
IF EXPR1=NULL
                RETURN EXPR2
ELSE
                       RETURN EXPR1

 

DECODE(AA﹐V1﹐R1﹐V2﹐R2....)函數
解釋:
IF AA=V1 THEN RETURN R1
IF AA=V2 THEN RETURN R2
..…
ELSE
RETURN NULL

 

LPAD(char1,n,char2)函數
解釋:
字符char1按制定的位數n顯示,不足的位數用char2字符串替換左邊的空位

 

字段名之間能夠進行算術運算
例如: (字段名1*字段名1)/3

 

查詢語句能夠嵌套
例如: SELECT …… FROM
(SELECT …… FROM表名1, [表名2, ……] WHERE 條件) WHERE 條件2; 
bitsCN_com關注網管是咱們的使命

 

兩個查詢語句的結果能夠作集合操做
例如: 並集UNION(去掉重複記錄), 並集UNION ALL(不去掉重複記錄), 差集MINUS, 交集INTERSECT

 

分組查詢
SELECT字段名1, 字段名2, …… FROM 表名1, [表名2, ……] GROUP BY字段名1
[HAVING 條件] ;

 

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

 

SELECT字段名1, 字段名2, …… FROM 表名1, [表名2, ……] WHERE
                表名1.字段名 = 表名2. 字段名 [ AND ……] ;

 

SELECT字段名1, 字段名2, …… FROM 表名1, [表名2, ……] WHERE
                表名1.字段名 = 表名2. 字段名(+) [ AND ……] ;

 

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

 

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

 

SELECT字段名1, 字段名2, …… FROM 表名1, [表名2, ……]
ORDER BY字段名1, 字段名2 DESC;

 

字符串模糊比較的方法

 

INSTR(字段名, ‘字符串’)>0
字段名 LIKE ‘字符串%’ [‘%字符串%’]

 

每一個表都有一個隱含的字段ROWID, 它標記着記錄的惟一性.

 

四.ORACLE裏經常使用的數據對象 (SCHEMA) 
1.索引 (INDEX)
CREATE INDEX 索引名ON 表名 ( 字段1, [字段2, ……] );
ALTER INDEX 索引名 REBUILD;

 

一個表的索引最好不要超過三個 (特殊的大表除外), 最好用單字段索引, 結合SQL語句的分析執行狀況,
也能夠創建多字段的組合索引和基於函數的索引

 

ORACLE8.1.7字符串能夠索引的最大長度爲1578 單字節
ORACLE8.0.6字符串能夠索引的最大長度爲758 單字節

 

2.視圖 (VIEW)
CREATE VIEW 視圖名AS SELECT …. FROM …..;
ALTER VIEW視圖名 COMPILE;

 

視圖僅是一個SQL查詢語句, 它能夠把表之間複雜的關係簡潔化.

 

3.同義詞 (SYNONMY)
CREATE SYNONYM同義詞名FOR 表名;
CREATE SYNONYM同義詞名FOR 表名@數據庫連接名;

 

4.數據庫連接 (DATABASE LINK)
CREATE DATABASE LINK數據庫連接名CONNECT TO 用戶名 IDENTIFIED BY 密碼 USING 
‘數據庫鏈接字符串’;

 

數據庫鏈接字符串能夠用NET8 EASY CONFIG或者直接修改TNSNAMES.ORA裏定義.

 

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

 

數據庫全局名稱能夠用如下命令查出
SELECT * FROM GLOBAL_NAME;

 

查詢遠端數據庫裏的表
SELECT …… FROM 表名@數據庫連接名;  http://www.bitscn.net/網管博客等你來搏

 

五.權限管理 (DCL) 語句
1.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 用戶名1, 用戶名2;

 

2.REVOKE 回收權限

 

REVOKE CONNECT, RESOURCE FROM 用戶名;
REVOKE SELECT ON 表名 FROM 用戶名;
REVOKE SELECT, INSERT, DELETE ON表名 FROM 用戶名1, 用戶名2;

 

查詢數據庫中第63號錯誤:
select orgaddr,destaddr from sm_histable0116 where error_code='63';

 

查詢數據庫中開戶用戶最大提交和最大下發數: select MSISDN,TCOS,OCOS from ms_usertable;

 

查詢數據庫中各類錯誤代碼的總和: 
bitsCN_com

 

select error_code,count(*) from sm_histable0513 group by error_code order by error_code;

 

查詢報表數據庫中話單統計種類查詢。
select sum(Successcount) from tbl_MiddleMt0411 where ServiceType2=111
select sum(successcount),servicetype from tbl_middlemt0411 group by servicetype

 

 

 

————————————————————————————————————————————————————————————————————————————————服務器

咱們常常會遇到須要表複製的狀況,如將一個table1的數據的部分字段複製到table2中,或者將整個table1複製到table2中,這時候咱們就要使用SELECT INTO 和 INSERT INTO SELECT 表複製語句了。session

1.INSERT INTO SELECT語句oracle

語句形式爲:Insert into Table2(field1,field2,...) select value1,value2,... from Table1編輯器

注意:(1)要求目標表Table2必須存在,而且字段field,field2...也必須存在ide

(2)注意Table2的主鍵約束,若是Table2有主鍵並且不爲空,則 field1, field2...中必須包括主鍵函數

(3)注意語法,不要加values,和插入一條數據的sql混了,不要寫成:

Insert into Table2(field1,field2,...) values (select value1,value2,... from Table1)

因爲目標表Table2已經存在,因此咱們除了插入源表Table1的字段外,還能夠插入常量。示例以下:

+ expand sourceview plaincopy to clipboardprint


    --1.建立測試表  
    create TABLE Table1  
    (  
        a varchar(10),  
        b varchar(10),  
        c varchar(10)
    )
    create TABLE Table2  
    (  
        a varchar(10),  
        c varchar(10),  
        d int
    )

    --2.建立測試數據  
    Insert into Table1 values('趙','asds','90')  
    Insert into Table1 values('錢','asds','100')  
    Insert into Table1 values('孫','asds','80')  
    Insert into Table1 values('李','asds',null)  

    select * from Table2


    --3.INSERT INTO SELECT語句複製表數據  
    Insert into Table2(a, c, d) select a,c,5 from Table1


    --4.顯示更新後的結果  
    select * from Table2  

    --5.刪除測試表  
    drop TABLE Table1  
    drop TABLE Table2



 

2.SELECT INTO FROM語句

語句形式爲:SELECT vale1, value2 into Table2 from Table1

要求目標表Table2不存在,由於在插入時會自動建立表Table2,並將Table1中指定字段數據複製到Table2中。示例以下:

view plaincopy to clipboardprint?
    --1.建立測試表  
    create TABLE Table1  
    (  
        a varchar(10),  
        b varchar(10),  
        c varchar(10)
    )

    --2.建立測試數據  
    Insert into Table1 values('趙','asds','90')  
    Insert into Table1 values('錢','asds','100')  
    Insert into Table1 values('孫','asds','80')  
    Insert into Table1 values('李','asds',null)  

    --3.SELECT INTO FROM語句建立表Table2並複製數據  
    select a,c INTO Table2 from Table1  
 
    --4.顯示更新後的結果  
    select * from Table2  

    --5.刪除測試表  
    drop TABLE Table1  
    drop TABLE Table2 


注意:若是在sql/plus或者PL/SQL執行這條語句,會報"ORA-00905:缺失關鍵字"錯誤,緣由是PL/Sql與T-SQL的區別。
T-SQL中該句正常,但PL/SQL中解釋是:
select..into is part of PL/SQL language which means you have to use it inside a PL/SQL block. You can not use it in a SQL statement outside of PL/SQL.
即不能單獨做爲一條sql語句執行,通常在PL/SQL程序塊(block)中使用。

 

若是想在PL/SQL中實現該功能,可以使用Create table newTable as select * from ...:
如: create table NewTable as select * from ATable;

NewTable 除了沒有,其餘的和ATable同樣

 

---------SQL SELECT INTO語法介紹
SQL SELECT INTO 語句可用於建立表的備份復件。
SELECT INTO 語句
SELECT INTO 語句從一個表中選取數據,而後把數據插入另外一個表中。
SELECT INTO 語句經常使用於建立表的備份復件或者用於對記錄進行存檔。
SQL SELECT INTO 語法
您能夠把全部的列插入新表
SELECT * INTO new_table_name [IN externaldatabase] FROM old_tablename
或者只把但願的列插入新表
SELECT column_name(s) INTO new_table_name [IN externaldatabase] FROM old_tablename
SQL SELECT INTO 實例 - 製做備份復件
下面的例子會製做 "Persons" 表的備份復件:
SELECT * INTO Persons_backup FROM Persons
IN 子句可用於向另外一個數據庫中拷貝表
SELECT * INTO Persons IN 'Backup.mdb' FROM Persons
若是咱們但願拷貝某些域,能夠在 SELECT 語句後列出這些域:
SELECT LastName,FirstName
INTO Persons_backup
FROM Persons
SQL SELECT INTO 實例 - 帶有 WHERE 子句
咱們也能夠添加 WHERE 子句。
下面的例子經過從 "Persons" 表中提取居住在 "Beijing" 的人的信息,建立了一個帶有兩個列的名爲 "Persons_backup" 的表:
SELECT LastName,Firstname INTO Persons_backup FROM Persons WHERE City='Beijing'
SQL SELECT INTO 實例 - 被鏈接的表
從一個以上的表中選取數據也是能夠作到的。
下面的例子會建立一個名爲 "Persons_Order_Backup" 的新表,其中包含了從 Persons 和 Orders 兩個表中取得的信息:
SELECT Persons.LastName,Orders.OrderNo
INTO Persons_Order_Backup
FROM Persons
INNER JOIN Orders
ON Persons.Id_P=Orders.Id_P

————————————————————————————————————————————————————————————————————

若是sql語句中有''(單引號或者雙引號)括的字符串,則須要同表中嚴格一致,否則會顯示「找不到行」這個錯誤。

alter語句的用法

alter語句的用法

須要修改結構的,就用到alter語句,方法以下:

ALTER TABLE語句用於修改已經存在的表的設計。

語法:ALTER TABLE table ADD COLUMN field type[(size)] [NOT NULL] [CONSTRAINT index]
ALTER TABLE table ADD CONSTRAINT multifieldindex
ALTER TABLE table DROP COLUMN field
ALTER TABLE table DROP CONSTRAINT indexname

說明:table參數用於指定要修改的表的名稱。
ADD COLUMN爲SQL的保留字,使用它將向表中添加字段。
ADD CONSTRAINT爲SQL的保留字,使用它將向表中添加索引。
DROP COLUMN爲SQL的保留字,使用它將向表中刪除字段。
DROP CONSTRAINT爲SQL的保留字,使用它將向表中刪除索引。
field指定要添加或刪除的字段的名稱。
type參數指定新建字段的數據類型。
size參數用於指定文本或二進制字段的長度。
indexname參數指定要刪除的多重字段索引的名稱。

用sql*plus或第三方能夠運行sql語句的程序登陸數據庫:

ALTER TABLE (表名) ADD (列名 數據類型);
ALTER TABLE (表名) MODIFY (列名 數據類型);
ALTER TABLE (表名) RENAME COLUMN (當前列名) TO (新列名); /////不須要括號
ALTER TABLE (表名) DROP COLUMN (列名);
ALTER TABLE (當前表名) RENAME TO (新表名);

如:
Alter Table Employ Add (weight Number(38,0)) ;

Alter Table Employ Modify (weight Number(13,2)) ;

Alter Table Emp Rename Cloumn weight To weight_new ;
ALTER TABLE emp DROP COLUMN weight_new ;

ALTER TABLE bouns RENAME TO bonus_new;
增長一個列:
ALTER TABLE 表名 ADD(列名 數據類型);
如:
ALTER TABLE emp ADD(weight NUMBER(38,0));

修改一個列的數據類型(通常限於修改長度,修改成一個不一樣類型時有諸多限制):
ALTER TABLE 表名 MODIFY(列名 數據類型);
如:
ALTER TABLE emp MODIFY(weight NUMBER(3,0) NOT NULL);

給列更名:
ALTER TABLE 表名 RENAME COLUMN 當前列名 TO 新列名;
如:
ALTER TABLE emp RENAME COLUMN weight TO weight_new;

刪除一個列:
ALTER TABLE 表名 DROP COLUMN 列名;
如:
ALTER TABLE emp DROP COLUMN weight_new;

將一個表更名:
ALTER TABLE 當前表名 RENAME TO 新表名;
如:
ALTER TABLE bouns RENAME TO bonus_new


====================================================================================
alter USER user IDENTIFIEDBY ’newpassword’REPLACE ’oldpassword’;

——————————————————————————————————————————————————————————————————————————

備份

 

Oracle數據導入導出imp/exp 
功能:Oracle數據導入導出imp/exp就至關與oracle數據還原與備份。
 
大多狀況均可以用Oracle數據導入導出完成數據的備份和還原(不會形成數據的丟失)。
 Oracle有個好處,雖然你的電腦不是服務器,可是你裝了oracle客戶端,並創建了鏈接
 (經過Net Configuration Assistant添加正確的服務命名,其實你能夠想成是客戶端與服務器端 修了條路,而後數據就能夠被拉過來了)
 這樣你能夠把數據導出到本地,雖然可能服務器離你很遠。
 你一樣能夠把dmp文件從本地導入到遠處的數據庫服務器中。
 利用這個功能你能夠構建倆個相同的數據庫,一個用來測試,一個用來正式使用。
 
執行環境:能夠在SQLPLUS.EXE或者DOS(命令行)中執行,
 DOS中能夠執行時因爲 在oracle 8i 中  安裝目錄\$ora10g\BIN被設置爲全局路徑,
 該目錄下有EXP.EXE與IMP.EXE文件被用來執行導入導出。
 oracle用java編寫,我想SQLPLUS.EXE、EXP.EXE、IMP.EXE這倆個文件是被包裝後的類文件。
 SQLPLUS.EXE調用EXP.EXE、IMP.EXE他們所包裹的類,完成導入導出功能。
 
下面介紹的是導入導出的實例,嚮導入導出看實例基本上就能夠完成,由於導入導出很簡單。
數據導出:
 1 將數據庫TEST徹底導出,用戶名system 密碼manager 導出到D:\daochu.dmp中
   exp system/manager@TEST file=d:\daochu.dmp full=y
 2 將數據庫中system用戶與sys用戶的表導出
   exp system/manager@TEST file=d:\daochu.dmp owner=(system,sys)
 3 將數據庫中的表table1 、table2導出
   exp system/manager@TEST file=d:\daochu.dmp tables=(table1,table2) 
 4 將數據庫中的表table1中的字段filed1以"00"打頭的數據導出
   exp system/manager@TEST file=d:\daochu.dmp tables=(table1) query=\" where filed1 like  '00%'\"
  
     上面是經常使用的導出,對於壓縮我不太在乎,用winzip把dmp文件能夠很好的壓縮。
                     不過在上面命令後面 加上 compress=y  就能夠了

數據的導入
 1 將D:\daochu.dmp 中的數據導入 TEST數據庫中。
   imp system/manager@TEST  file=d:\daochu.dmp
   上面可能有點問題,由於有的表已經存在,而後它就報錯,對該表就不進行導入。
   在後面加上 ignore=y 就能夠了。
 2 將d:\daochu.dmp中的表table1 導入
 imp system/manager@TEST  file=d:\daochu.dmp  tables=(table1) 
 
 基本上上面的導入導出夠用了。很多狀況我是將表完全刪除,而後導入。
 
注意:
 你要有足夠的權限,權限不夠它會提示你。
 數據庫時能夠連上的。能夠用tnsping TEST 來得到數據庫TEST可否連上。

 

數據導出:
exp hkb/hkb@boss_14 full=y file=c:\orabackup\hkbfull.dmp log=c:\orabackup\hkbfull.log;

導出注意事項:導出的是當前用戶的的數據,當前用戶若是有DBA的權限,則導出全部數據!

同名用戶之間的數據導入:
imp hkb/hkb@xe  file=c:\orabackup\hkbfull.dmp log=c:\orabackup\hkbimp.log full=y

不一樣名之間的數據導入:
imp system/test@xe fromuser=hkb touser=hkb_new file=c:\orabackup\hkbfull.dmp

log=c:\orabackup\hkbimp.log;

相關文章
相關標籤/搜索