sql學習筆記

060302sql學習筆記

**********************************建表*****************************

create table student

(id  number primary key   --主鍵

student_id varchar2(10) reference people(student_id),  --外鍵,這一列是引用另一表的一列

name varchar2(20) not null,

score   number check(score>0 and score<=100)

unique (name)                 --唯一約束

)

******************************修改表結構***************************

alter table student

modify name  varchar2(25)

alter table student

add(telephone varchar2(10))

提示:ALTFR語句不允許不加區分地更改數據類型和列的大小  一般情況下、列中

所有的數據都必須遵循新的數據類型,並適合新列的大小,否則列個必須不包含任何

值。

******************************刪除表**********************************

drop table student

*****************************增、改、刪*****************************

insert into people(id,name)

values(1,'songyc')

update student

set name='songyc'

where id=1

delete from student

where id=1000

從表中刪除所有行

truncate table student 效果與delete from student一樣

二者效率差很多,前者一次執行,後者對每條記錄執行,所以前者快的多

*****************************使用特殊表dual***********************

select 2*2-8 from dual

提示:在oracle數據庫中,dual是特殊的表  簡單地說是沒有包含行和列的

表。在需要編寫不必返回任何存儲在數據庫中的數據的查詢時.可以將Dual指定爲

表來查詢。

對UPPER()、RtriM(),rTRIM()函數空白從字符串尾部刪除,uPPER()函數將字符本身所有的小寫都轉換成大寫字母

如果where name=''的字符串中需要包含單引號該怎麼辦?

你需要在字符串中用兩個單引號,來表示名稱中的引號是作比較的字符串的一部分,而不是結束字符串的字符,如:where name='song''yongcong'

***************************投影、聯接*********************************

投影:返回指定列的查詢結果 select a,b from tb

聯接:select aa.a,bb.b from aa,bb where aa.a=bb.a

***************************劣質數據庫特徵***************************************

●列或表具有令人困惑或不明確的名稱:

●需要用戶對同樣的數據輸入多次,或者在一次更新中要在在多個位置更改同一條數據的值

●允許數據庫中的數據不同步,使得尋找同一條信息的多條查詢返回不問的結果

●劣質性能。設計不良的數據庫返問查詢結果的速度遠遠慢於它們應有的速度,所以數據庫庫應用程序更難使用。

●決定數據之間的關係很困難。

●在單獨的表中複製行

****************************設計數據庫***************************************

1、信息收集。很明顯,在設計數據庫之前,需要確切知道數據庫個將要存儲什麼東西。

2、製作詳細目錄。在找到將要存儲在數據庫中的全部信息後,需要創建一個清單,包含

所有找到的數據的類型和那些類型的屬性。

3、實體&emdash;關係建模。將數據按單獨的實體和實體屬性來排列。決定這些實體的關係;

4、決定數據庫需要哪&emdash;級規範化。將規範側IJ應用到數據巾,直到數據符合選擇的範式。

5、編寫成建數據庫所需的sQL代碼,然後在關係數據庫系統中創建數據庫。

6、決定用戶用何種方式訪問數據,然後賦予用戶適當的訪問權級別。

7、用數據爲數據庫增值。

****************************創建索引*********************************************

create index person_full_name on people(person_fname,person_lname)

create unique index person_full_name on people(person_fname,person_lname) --唯一索引

*****************************導表*************************************************

insert into stu

select * from student --要求表結構一致

<>是sql標準的不等於運算符,雖然很多廠商採納了!=但是這不標準。

字符串比較要避免大小寫問題

lower(name)='songyc'

******************************處理空值**************************************

空值最早在第3章中介紹過,當時討論了它們對數據庫設計的影響c在從數據庫小選擇

數據時,空值可以在某種程度上聚合,這是因爲它們不能用標服的比較運算符來檢驗、比較運

算符不能處理串值,因爲它們將空值作爲未知來考慮,所以空值不被看作與任何值相等,甚至

不與另外的空值相等。

用is null 或 is not null

有引號的null和沒有引號的null截然不同。

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

2001-08 餘楓編

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

1.INSERT  (往數據表裏插入記錄的語句)

INSERT INTO 表名(字段名1, 字段名2, &ldots;&ldots;) VALUES ( 值1, 值2, &ldots;&ldots;);

INSERT INTO 表名(字段名1, 字段名2, &ldots;&ldots;)  SELECT 字段名1, 字段名2, &ldots;&ldots; FROM 另外的表名;

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

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

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

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

或者用字符串轉換成日期型函數TO_DATE(&rsquor;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, &ldots;&ldots; 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, &ldots;&ldots; FROM 表名1, [表名2, &ldots;&ldots;] 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

..&ldots;

ELSE

RETURN NULL

LPAD(char1,n,char2)函數

解釋:

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

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

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

查詢語句可以嵌套

例如: SELECT &ldots;&ldots; FROM

(SELECT &ldots;&ldots; FROM表名1, [表名2, &ldots;&ldots;] WHERE 條件) WHERE 條件2;

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

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

分組查詢

SELECT字段名1, 字段名2, &ldots;&ldots; FROM 表名1, [表名2, &ldots;&ldots;] GROUP BY字段名1

[HAVING 條件] ;

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

SELECT字段名1, 字段名2, &ldots;&ldots; FROM 表名1, [表名2, &ldots;&ldots;] WHERE

表名1.字段名 = 表名2. 字段名 [ AND &ldots;&ldots;] ;

SELECT字段名1, 字段名2, &ldots;&ldots; FROM 表名1, [表名2, &ldots;&ldots;] WHERE

表名1.字段名 = 表名2. 字段名(+) [ AND &ldots;&ldots;] ;

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

 

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

SELECT字段名1, 字段名2, &ldots;&ldots; FROM 表名1, [表名2, &ldots;&ldots;]

ORDER BY字段名1, 字段名2 DESC;

字符串模糊比較的方法

INSTR(字段名, &rsquor;字符串’)>0

字段名 LIKE  &rsquor;字符串%’  [&rsquor;%字符串%’]

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

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

1.索引 (INDEX)

CREATE INDEX 索引名ON 表名 ( 字段1, [字段2, &ldots;&ldots;] );

ALTER INDEX 索引名 REBUILD;

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

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

ORACLE8.1.7字符串可以索引的最大長度爲1578 單字節

ORACLE8.0.6字符串可以索引的最大長度爲758 單字節

ORACLE DOC上說字符串最大可以建索引的長度約是:數據塊的大小(db_block_size)*40%

2.視圖 (VIEW)

CREATE VIEW 視圖名AS SELECT &ldots;. FROM &ldots;..;

ALTER VIEW視圖名 COMPILE;

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

3.同義詞 (SYNONMY)

CREATE SYNONYM同義詞名FOR 表名;

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

4.數據庫鏈接 (DATABASE LINK)

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

 

數據庫連接字符串可以用NET8 EASY CONFIG或者直接修改TNSNAMES.ORA裏定義.

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

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

SELECT * FROM GLOBAL_NAME;

查詢遠端數據庫裏的表

SELECT &ldots;&ldots; 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;

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章