<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    飛翔的起點

    從這里出發

    導航

    <2008年4月>
    303112345
    6789101112
    13141516171819
    20212223242526
    27282930123
    45678910

    統計

    常用鏈接

    留言簿(5)

    隨筆分類

    隨筆檔案

    文章分類

    文章檔案

    搜索

    最新評論

    閱讀排行榜

    評論排行榜

    關于oracle的一些問題

    刪除重復記錄:

                           

    辦法一:
    DELETE FROM TAB1 A
    WHERE A.ROWID > ( SELECT MIN(B.ROWID) FROM TAB1 B WHERE A.字段=B.字段 );
    其中子查詢中的“WHERE A.字段=B.字段”用來寫明重復條件。

                           
    ——這一辦法在數據記錄超過10萬時一般都會變得很慢。

    辦法二:
    --建立臨時表,--清空原表,--插回原表,如下例:
    create table temp_emp as (select distinct * from employee) ;
    truncate table employee;
    insert into employee select * from temp_emp;

                           
    ——這一辦法適用于較大的表的情況。因為是塊操作,對應于大表效率會好很多。

                           

    posted @ 2006-09-11 13:34 K 閱讀(39) | 評論 (0)編輯

    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 表名;
     
    ORACLE 常用的SQL語法和數據對象
    作者:網絡 佚名   更新時間:2005-08-20    收藏此頁 
     
     
     三.查詢語句 (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;

      兩個查詢語句的結果可以做集合操作
      例如: 并集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 表名@數據庫鏈接名;

      五.權限管理 (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;

    posted on 2008-04-09 09:59 forgood 閱讀(356) 評論(3)  編輯  收藏

    評論

    # re: 關于oracle的一些問題 2008-04-09 10:01 forgood

    刪除重復記錄中的第一種方法不是很明白????
      回復  更多評論   

    # re: 關于oracle的一些問題 2008-04-14 16:31 forgood

    select 字段...... into 表1 from 條件。這個語句中在執行前,表1是不存在的,在執行這條語句的時候會自動創建表1.  回復  更多評論   

    # re: 關于oracle的一些問題 2008-04-23 09:55 forgood

    select * into destTbl from srcTbl

    insert into destTbl(fld1, fld2) select fld1, 5 from srcTbl

    以上兩句都是將 srcTbl 的數據插入到 destTbl,但兩句又有區別的。

    第一句(select into from)要求目標表(destTbl)不存在,因為在插入時會自動創建。

    第二句(insert into select from)要求目標表(destTbl)存在,由于目標表已經存在,所以我們除了插入源表(srcTbl)的字段外,還可以插入常量
      回復  更多評論   


    只有注冊用戶登錄后才能發表評論。


    網站導航:
     
    主站蜘蛛池模板: 国产成人AV片无码免费| 男女拍拍拍免费视频网站| 日本片免费观看一区二区| 亚洲成AV人片在线观看| 花蝴蝶免费视频在线观看高清版 | 亚洲男人的天堂久久精品| 久99久精品免费视频热77| 精品亚洲永久免费精品| 久久精品视频免费| 亚洲国产精品久久| 5555在线播放免费播放| 亚洲av成人一区二区三区| 午夜免费福利影院| 羞羞漫画在线成人漫画阅读免费| 一级做a爰片性色毛片免费网站| av永久免费网站在线观看| 亚洲区小说区图片区| 成全视频免费观看在线看| 久久久久久亚洲AV无码专区| 国产在线观看麻豆91精品免费| 亚洲一区二区三区无码影院| 巨胸喷奶水视频www免费视频 | 91免费资源网站入口| 亚洲色偷偷偷综合网| 亚洲精品黄色视频在线观看免费资源| 老司机亚洲精品影院无码| 国产电影午夜成年免费视频 | 18禁黄网站禁片免费观看不卡| 免费在线观看理论片| 97在线免费视频| 亚洲日本在线免费观看| 日本一道本高清免费| 三年片在线观看免费观看大全中国| 成人性生交大片免费看无遮挡| 亚洲色成人中文字幕网站| 暖暖日本免费中文字幕| 亚洲乱码在线卡一卡二卡新区| 99爱免费观看视频在线| 亚洲AV日韩AV无码污污网站| 精品亚洲成α人无码成α在线观看 | 亚洲午夜av影院|