數據庫SQL---數據庫、基本表、視圖、索引的定義、修改、刪除

一、SQL(結構化查詢語言)的組成:數據定義語言DDL、數據操縱語言DML、數據控制語言DCL、其餘。sql

二、SQL語言的功能:數據庫

1)數據查詢:SELECTapp

2)數據定義:CREATE   DROP  ALTER代理

3)數據操縱:INSERT  UPDATE  DELETE對象

4)數據控制:GRANT  REVOKE索引

三、SQL語言的操做對象事務

1)基本表:數據庫中獨立存在的表。字符串

2)視圖:從一個或幾個基本表中導出的表,是虛表,只存放視圖的定義,不存放對應的數據。table

3)查詢表:查詢結果對應的表。集羣

4)存儲文件:數據庫中存放關係的物理文件。

四、表的相關數據
1)字段:一個事物的某一特徵
2)記錄:字段的組合,表示的是一個具體的事物
3)表:記錄的組合,表示的是同一類型事物的集合
4)表和字段、記錄的關係:字段是事物的屬性、記錄是事物自己、表是事物的集合
5)列:字段的另外一種稱謂
6)屬性:字段的另外一種稱謂
7)元組:記錄的另外一種稱謂

五、數據庫中建表方法

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),
)

六、修改表

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)

七、刪除表

delete table emp

八、約束:對一個表中的屬性操做的限制叫作約束。
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規定的那個值。
九、表和約束的區別
1)數據庫是經過表來解決事物的存儲問題的
2)數據庫是經過約束來解決事物取值的有效性和合法性的問題
3)建表的過程就是指定事物屬性及其事物屬性各類約束的過程。
十、關係:表和表之間的聯繫。
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)
)

十一、主鍵:可以惟一標識一個事務的一個字段或者多個字段的組合,被稱爲主鍵。
1)含有主鍵的表稱爲主鍵表。
2)主鍵一般是證書,不建議使用字符串作主鍵(若是主鍵是用於集羣式服務,能夠考慮用字符串當主鍵)。
3)主鍵的值一般都不容許修改,除非本記錄被刪除。
4)主鍵不要定義成id,而要定義成表名ID或者表名_id。
5)要用代理主鍵,不能用業務主鍵
      任何一張表,強烈建議不要使用有業務含義的字段充當主鍵。
      一般都是在表中單獨添加一個整形的編號充當主鍵字段。
十二、外鍵:若是一個表中的若干個字段是來自另外若干個表的主鍵或惟一鍵,則這若干個字段就是外鍵。
1)外鍵一般是來自另外一個表的主鍵而不是惟一鍵,由於惟一鍵可能爲空。
2)外鍵不必定是來自另外的表,也可能來自本表的主鍵。
1三、先刪主鍵表仍是外鍵表
        先刪外鍵表,若是先刪主鍵表會報錯,由於這會致使外鍵表中的數據引用失敗。

1四、視圖:視圖從代碼上看是一個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)視圖的缺點:增長了數據庫維護成本;視圖只是簡化了查詢,可是不能加快查詢的速度。

1五、索引

1)建立索引

create index studentidx on student(stu_id,stu_name)

2)刪除索引

drop index studentidx

相關文章
相關標籤/搜索