<dfn id="w48us"></dfn><ul id="w48us"></ul>
  • <ul id="w48us"></ul>
  • <del id="w48us"></del>
    <ul id="w48us"></ul>
  • ORACLE 常用的SQL語法和數據部分

    時間:2024-06-22 16:59:55 SQL 我要投稿
    • 相關推薦

    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語法和數據部分】相關文章:

    oracle的sql語句01-21

    SQL Server常用數據類型06-18

    Oracle的sql語句模擬試題及答案10-12

    oracle數據庫基本語句02-08

    Oracle數據庫認證層次08-29

    Oracle數據庫SELECT語句10-25

    Oracle數據庫語句大全12-21

    ORACLE數據字典的有效利用08-24

    oracle數據庫基礎知識01-21

    Oracle 數據庫查詢小技巧10-17

    主站蜘蛛池模板: 久久伊人精品青青草原日本| 亚洲精品亚洲人成人网| 无码精品人妻一区二区三区影院| 国产精品免费一区二区三区四区| 人妻少妇精品久久| 亚洲国产精品久久久久婷婷软件| 久久亚洲日韩精品一区二区三区| 久久精品成人| 国产精品日韩欧美在线第3页| 国产夫妇精品自在线| 久久精品国产网红主播| 亚洲综合欧美精品一区二区| 欧美国产精品久久高清| 国产午夜福利精品久久| 69堂午夜精品视频在线| 国产精品免费网站| 国产亚洲欧美精品永久| 人人妻人人澡人人爽人人精品电影 | 亚洲精品无码成人片久久| 精品综合久久久久久88小说| 99久久夜色精品国产网站| 亚洲国产成人久久精品影视| 久久精品国产精品青草 | 久久精品无码专区免费青青| 亚洲日韩精品一区二区三区 | 国产成人精品精品欧美| AV无码精品一区二区三区| 国产精品视频第一区二区三区| 国产午夜福利精品久久2021| 久久精品国产亚洲AV香蕉| 久久99精品久久久久婷婷| 久久精品国产亚洲AV无码麻豆 | 久久久久久国产精品无码下载| 精品乱子伦一区二区三区| 久久久久人妻一区精品| 四虎精品影库4HUTV四虎| 亚洲日韩中文在线精品第一| 少妇伦子伦精品无码STYLES| 久久精品水蜜桃av综合天堂| 国产精品国产三级国产AV主播 | 日韩一区二区三区精品|