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

来源:https://www.cnblogs.com/xqy1874/archive/2020/04/30/12809391.html
-Advertisement-
Play Games

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


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • [TOC] 前言 DDL DDL,中文為數據定義語言,DDL的特點是對資料庫內部的對象進行create(創建)、alter(修改)、drop(刪除)等操作,負責管理資料庫的基礎數據,不涉及對錶中內容的操作和更改。 DCL DCL,中文為數據控制語言,DDL的特點是對資料庫內部的對象grant(用戶授 ...
  • 當安裝alluxio時,出現允許打開的文件數目過小問題: The user limit for number of open files is too small. The current value is 4096. For production use, it should be bigger ...
  • [TOC] MySQL全庫備份腳本 ...
  • 本文主要介紹 COM 的基礎知識,傾向於理論性的理解,面向初學者,淺嘗輒止。 1. COM 是什麼: COM 的英文全稱是,Component Object Model,中文譯為,組件對象模型。它官方的概念是:The Microsoft Component Object Model (COM) is ...
  • 1、索引 1-1、索引的概述 我們把一個表中的一列或者多列和列中元素所在表中記錄的物理地址組合成一個新的表。這個表的記錄大致為列的內容和該列所在記錄的物理地址。 1-2、索引的優缺點 www.2cto.com 優點:大大加快了對源表的執行速度,我們對索引表的檢索就可以實現對源表的檢索。到底快在哪裡? ...
  • 很多程式員都學過MySQL,而且也會寫SQL語句。但僅僅會寫還遠遠不夠,在面試中以及在工作中,還必須要會事務和併發。 一、事務 事務是滿足 ACID 特性的操作,可以通過 Commit 提交事務,也可以使用 Rollback 進行回滾。 A(Atomicity)原子性:事務被視為不可分割的小單元,事 ...
  • 一、SDS 1、SDS結構體 redis3.2之前 :不管buf的位元組數有多少,都用 4位元組的len來儲存長度 ,對於只存短字元串那麼優點 浪費空間 ,比如只存 ,則 則只需要一個位元組8位即可表示 redis3.2之後: \__attribute__ ((\__packed__)) 關鍵字是為了取消 ...
  • MongoDB Limit() 方法 如果你需要在MongoDB中讀取指定數量的數據記錄,可以使用MongoDB的Limit方法,limit()方法接受一個數字參數,該參數指定從MongoDB中讀取的記錄條數。 語法 >db.COLLECTION_NAME.find().limit(NUMBER) ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...