1、SQL(結構化查詢語言)的組成:數據定義語言DDL、數據操縱語言DML、數據控制語言DCL、其他。 2、SQL語言的功能: 1)數據查詢:SELECT 2)數據定義:CREATE DROP ALTER 3)數據操縱:INSERT UPDATE DELETE 4)數據控制:GRANT REVOKE ...
1、SQL(結構化查詢語言)的組成:數據定義語言DDL、數據操縱語言DML、數據控制語言DCL、其他。
2、SQL語言的功能:
1)數據查詢:SELECT
2)數據定義:CREATE DROP ALTER
3)數據操縱:INSERT UPDATE DELETE
4)數據控制:GRANT REVOKE
3、SQL語言的操作對象
1)基本表:資料庫中獨立存在的表。
2)視圖:從一個或幾個基本表中導出的表,是虛表,只存放視圖的定義,不存放對應的數據。
3)查詢表:查詢結果對應的表。
4)存儲文件:資料庫中存放關係的物理文件。
4、表的相關數據
1)欄位:一個事物的某一特征
2)記錄:欄位的組合,表示的是一個具體的事物
3)表:記錄的組合,表示的是同一類型事物的集合
4)表和欄位、記錄的關係:欄位是事物的屬性、記錄是事物本身、表是事物的集合
5)列:欄位的另一種稱謂
6)屬性:欄位的另一種稱謂
7)元組:記錄的另一種稱謂
5、資料庫中建表方法
1)利用圖形化界面建表
2)create table命令
create table dept(
dept_id int primary key,
dept_name nvarchar(100) not null,
dept_address nvarchar(100)
) 最後一行的逗號可以有也可以沒有,在ORACLE里不能有,所以建議不寫逗號,便於移植。 create table emp
( --不能寫成{
emp_id int constraint pk_emp_id_hahaha primary key,
emp_name nvarchar(20) not null,
emp_sex nchar(1) ,
dept_id int constraint fk_dept_id_heihei foreign key references dept(dept_id),
)
6、修改表
1)增加列(新增一列的值為空值)
alter table dept add dept_new int default 0
2)增加約束
alter table dept add constraint dept_name unique
3)刪除約束
alter table dept drop constraint dept_name unique
4)修改列的數據類型
alter table dept alter column dept_name char(10)
7、刪除表
delete table emp
8、約束:對一個表中的屬性操作的限制叫做約束。
1)主鍵約束:不允許重覆元素,避免數據的冗餘。
2)外鍵約束:通過外鍵約束從語法上保證了本事務所關聯的其他事物一定是存在的。
事物與事物之間的關係是通過外鍵來體現的。
3)create約束:保證事物屬性的取值在合法的範圍之內。
create table student
(stu_id int primary key,
stu_sal int check (stu_sal>1000 and stu_sal<=8000),
stu_sex nchar(1) default('男') ---()可以省,在資料庫中字元串是必須用''括起來的
)
4)default約束:保證事物的屬性一定會有一個值
5)唯一約束:保證了事物屬性的取值不允許重覆,但允許其中有一列且只能有一列為空。
(1)SqlServer只允許一個unique列為空,Oracle允許多個unique列為空
(2)create table student2
(stu_id int primary key,
stu_sal int check (stu_sal>1000 and stu_sal<=8000),
stu_sex nchar(1) default('男'), ---()可以省,在資料庫中字元串是必須用''括起來的
stu_name nvarchar(200) unique
)
insert into student2 values(1,6000,‘男’,‘張三’); ---ok
insert into student2 values(2,6000,‘男’,‘張三’);---error違反了唯一約束
insert into student2 values(2,6000,‘男’,‘李四’);---ok
insert into student2 values(null,6000,‘男’,‘王五’);---error主鍵不能為空,出錯的信息是“不能將值null插入列‘stu_id’”
insert into student2 values(3,6000,‘男’,null);---ok 說明唯一鍵可以為空
stu_name nvarchar(200) unique not null---error兩者可以組合使用
6)not null約束
(1)要求用戶必須為該屬性賦一個值,否則語法出錯。
(2)如果一個欄位不寫null也不寫not null,則預設是null,即預設允許為空,用戶可以不給該欄位賦值。
(3)如果用戶沒有為該欄位賦值,則該欄位的值預設是null。
(4)要註意null和default的區別
相同點:都允許用戶不賦值。
不同點:null修飾的欄位如果用戶不賦值則預設是null。
default修飾的欄位如果用戶不賦值則預設是default規定的那個值。
9、表和約束的區別
1)資料庫是通過表來解決事物的存儲問題的
2)資料庫是通過約束來解決事物取值的有效性和合法性的問題
3)建表的過程就是指定事物屬性及其事物屬性各種約束的過程。
10、關係:表和表之間的聯繫。
1)實現方式:通過設置不同形式的外鍵來體現報和表的不同關係。
2)分類(假設是A表和B表):
(1)一對一:既可以把表A的主鍵充當表B的外鍵,也可以把表B的主鍵充當表A的外鍵。
(2)一對多:把A表的主鍵充當B表的外鍵,或者講:把A表的主鍵添加到B表來充當B表的外鍵。在多的一方添加外鍵。
(3)多對多:多對多必須的通過單獨的一張表來表示
create table banji
(
banji_id int primary key,
banji_num int not null,
banji_name nvarchar(100)
) --教師
create table jiaoshi
(
jiaoshi_id int primary key,
jiaoshi_name nvarchar(200)
) --第三張表 用來模擬班級和教師的關係
create table banji_jiaoshi_mapping
(
banji_id int constraint fk_banji_id foreign key references banji(banji_id),
jiaoshi_id int foreign key references jiaoshi(jiaoshi_id),
kecheng nvarchar(20),
constraint pk_banji_id_jiaoshi_id primary key (banji_id, jiaoshi_id, kecheng)
)
11、主鍵:能夠唯一標識一個事務的一個欄位或者多個欄位的組合,被稱為主鍵。
1)含有主鍵的表稱為主鍵表。
2)主鍵通常是證書,不建議使用字元串做主鍵(如果主鍵是用於集群式服務,可以考慮用字元串當主鍵)。
3)主鍵的值通常都不允許修改,除非本記錄被刪除。
4)主鍵不要定義成id,而要定義成表名ID或者表名_id。
5)要用代理主鍵,不能用業務主鍵
任何一張表,強烈建議不要使用有業務含義的欄位充當主鍵。
通常都是在表中單獨添加一個整形的編號充當主鍵欄位。
12、外鍵:如果一個表中的若幹個欄位是來自另外若幹個表的主鍵或唯一鍵,則這若幹個欄位就是外鍵。
1)外鍵通常是來自另一個表的主鍵而不是唯一鍵,因為唯一鍵可能為空。
2)外鍵不一定是來自另外的表,也可能來自本表的主鍵。
13、先刪主鍵表還是外鍵表
先刪外鍵表,如果先刪主鍵表會報錯,因為這會導致外鍵表中的數據引用失敗。
14、視圖:視圖從代碼上看是一個select語句,從邏輯上看被當做一個虛擬表看待。
1)為什麼需要視圖
簡化查詢:避免了代碼的冗餘、避免了書寫大量重覆的sql語句。
2)如何創建視圖
create view 視圖的名字 as
---select的前面不能添加begin
select語句
---select的後面不能添加end
3)創建視圖的select語句必須要為所有的計算列指定別名
---錯誤
create view v$_a
as
select avg(sal) from emp;
---正確
create view v$_a
as
select avg(sal) as "avg_sal" from emp;
4)視圖不是物理表,是虛擬表,不建議通過視圖更新視圖所依附的原始表的數據或結構
(1)視圖的優點:簡化查詢、增加數據的保密性。
(2)視圖的缺點:增加了資料庫維護成本;視圖只是簡化了查詢,但是不能加快查詢的速度。
15、索引
1)創建索引
create index studentidx on student(stu_id,stu_name)
2)刪除索引
drop index studentidx