【SQL必知必會筆記(1)】數據庫基礎、SQL、MySQL8.0.16下數據庫、表的創建及數據插入


1.數據庫基礎

SQL是一種專門用來與數據庫溝通的語言,因此在學習SQL之前,我們應該對數據庫數據庫技術的某些基本概念有所瞭解。

本節主要介紹數據庫及數據庫技術的重要基本概念

1.1 數據庫(database)

  • 數據庫:保存//有組織的數據//的容器(通常是一個文件或者一組文件)。
    最簡單的辦法是將數據庫想象爲一個文件櫃。這個文件櫃是一個存放數據的物理位置,不管數據是什麼,也不管數據是如何組織的。

注意:

  • 我們常說的數據庫軟件,應該稱爲數據庫管理系統(DBMS)
  • 數據庫,則是通過DBMS操縱的容器

1.2 表(table)

你往文件櫃裏放資料時,並不是隨便將他們扔進某個抽屜就完事了,而是在文件櫃中創建文件,然後將相關的資料放入特定的文件中。

在數據庫領域中,這種文件稱爲表。表是一種結構化的文件,可以用來存儲某種特定類型的數據。例如,表可以保存顧客清單、產品目錄,或者其他信息清單。

  • 表:某種特定類型數據結構化清單

    這裏的關鍵一點在於,存儲在表中的數據是同一類型的數據或清單。
    但是這裏的類型不是指數據類型,比如,不應該將顧客的清單與訂單的清單存儲在同一個數據庫表中,
    顧客的清單爲一個類型,訂單的清單爲一個類型。
    
  • 表名:每個表都有一個名字來標識自己,這個名字在同一個數據庫中是唯一的。

    說明:使表名成爲唯一的,實際上是數據庫名和表名等的組合。有的數據庫還使用數據庫擁有者的名字作爲唯一名的一部分。
    也就是說,雖然在相同的數據庫中不能兩次使用相同的表名,但在不同的數據庫中完全可以使用相同的表名。
    

表具有一些特性,這些特性定義了數據在表中如何存儲,包含存儲什麼樣的數據、數據如何分解、各部分信息如何命名等信息。

描述表的這組信息就是所謂的模式。

  • 模式(schema):關於數據庫和表佈局及特性的信息。

    模式可以用來描述數據庫中特定的表,也可以用來描述整個數據庫(和其中表的關係)。
    

1.3 列和數據類型

  • 列(column):表中的一個字段

    所有表都是由一個或多個列組成的;
    列儲存表中某部分的信息。
    

可以根據自己的具體需求,來決定把數據分解到何種程度。

  • 數據類型(datatype):所允許的//數據的類型,定義了列可以存儲哪些數據種類

    每個表列都有相應的數據類型,它限制(或允許)該列中存儲的數據。
    

數據類型還幫助正確地分類數據,並在優化磁盤使用方面起到重要的作用。因此,在創建表時必須特別關注所用的數據類型。
注意: 數據類型兼容。在創建表結構時,要注意不同DBMS在數據類型種類、名稱等方面的差異。

1.4 行

  • 行(row):表中的一個記錄

    表中的數據是按行存儲的,所保存的每個記錄存儲在自己的行內。
    

1.5 主鍵

  • 主鍵(primary key):一列(或一組列),其值能夠唯一標識表中的每一行

提示:應該總是定義主鍵。雖然並不總是需要主鍵,但多數數據庫設計者都會保證他們創建的每個表具有一個主鍵,以便於以後的數據操作和管理。

表中的任何列都可以作爲主鍵,只要它滿足以下條件

  • 任意兩行都具有相同的主鍵值;
  • 每一行必須具有一個主鍵值(主鍵列不允許NULL值);
  • 主鍵列中的值不允許修改或更新;
  • 主鍵值不能重用(如果某行從表中刪除,它的主鍵不能賦給以後的新行)

可以用一列或多列作爲主鍵,在使用多列作爲主鍵時:

  • 上述條件必須應用到//作爲主鍵的//所有列,所有列值的組合必須是唯一的(但單個列的值可以不唯一)

2.什麼是SQL

SQL:是結構化查詢語言(Structured Query Language)的縮寫,是一種專門用來與//數據庫//溝通的語言。

設計SQL的目的:提供一種從數據庫讀寫數據的簡單有效的方法。

SQL的優點:

  • 幾乎所有重要的DBMS支持SQL,所以學習此語言使我們幾乎能與所有數據庫打交道。
  • 簡單易學。SQL的語句全都是由有很強描述性的英語單詞組成,而且這些單詞的數目不多
  • SQL雖然看上去很簡單,但實際上是一種強有力的語言,靈活使用其語言元素,可以進行非常複雜和高級的數據庫操作。

說明:

  • SQL的擴展。許多DBMS廠商通過增加語句或指令,對SQL進行了擴展。這種擴展的目的是提供執行特定操作額外功能簡化方法
  • 標準SQL由ANSI標準委員會管理,從而稱爲ANSI SQL
  • 所有主要的DBMS,都支持ANSI SQL,也有自己的擴展。各個實現都有自己的名稱,如PL/SQL、Transact-SQL等。
  • 本系列筆記所涉及的主要是ANSI SQL。在使用某種DBMS特定的SQL時,會特別說明。

3.創建後續練習所需數據庫、表(MySQL8.0.16)

3.1 創建數據庫

成功登陸MySQL之後,執行CREATE DATABASE tysql;,創建數據庫tysql;
然後執行USE tysql;,使用tysql數據庫。

下面的一系列操作就是在tysql創建各種數據表,並規定主、外鍵約束,插入數據

3.2 創建數據庫表

編寫SQL語句需要良好地理解基本數據庫設計。如果不知道什麼信息存放在什麼表中,表與表之間如何互相關聯,行中數據如何分解,那麼編寫高效的SQL是不可能的。

數據庫管理員通常使用關係圖來說明數據庫表的關聯方式外鍵定義了這些關係。下圖是要創建的5個表的關係圖:
在這裏插入圖片描述

3.2.1開始創建數據庫表

  • Customers表
CREATE TABLE Customers
(
  cust_id      char(10)  NOT NULL ,
  cust_name    char(50)  NOT NULL ,
  cust_address char(50)  NULL ,
  cust_city    char(50)  NULL ,
  cust_state   char(5)   NULL ,
  cust_zip     char(10)  NULL ,
  cust_country char(50)  NULL ,
  cust_contact char(50)  NULL ,
  cust_email   char(255) NULL 
);
  • OrderItems表
CREATE TABLE OrderItems
(
  order_num  int          NOT NULL ,
  order_item int          NOT NULL ,
  prod_id    char(10)     NOT NULL ,
  quantity   int          NOT NULL ,
  item_price decimal(8,2) NOT NULL 
);
  • Orders表
CREATE TABLE Orders
(
  order_num  int      NOT NULL ,
  order_date datetime NOT NULL ,
  cust_id    char(10) NOT NULL 
);
  • Products表
CREATE TABLE Products
(
  prod_id    char(10)      NOT NULL ,
  vend_id    char(10)      NOT NULL ,
  prod_name  char(255)     NOT NULL ,
  prod_price decimal(8,2)  NOT NULL ,
  prod_desc  text          NULL 
);
  • Vendors表
CREATE TABLE Vendors
(
  vend_id      char(10) NOT NULL ,
  vend_name    char(50) NOT NULL ,
  vend_address char(50) NULL ,
  vend_city    char(50) NULL ,
  vend_state   char(5)  NULL ,
  vend_zip     char(10) NULL ,
  vend_country char(50) NULL 
);

3.2.2 爲各表定義主、外鍵約束

  • 定義主鍵約束:
ALTER TABLE Customers ADD PRIMARY KEY (cust_id);
ALTER TABLE OrderItems ADD PRIMARY KEY (order_num, order_item);
ALTER TABLE Orders ADD PRIMARY KEY (order_num);
ALTER TABLE Products ADD PRIMARY KEY (prod_id);
ALTER TABLE Vendors ADD PRIMARY KEY (vend_id);
  • 定義外鍵約束:
ALTER TABLE OrderItems ADD CONSTRAINT FK_OrderItems_Orders FOREIGN KEY (order_num) REFERENCES Orders (order_num);
ALTER TABLE OrderItems ADD CONSTRAINT FK_OrderItems_Products FOREIGN KEY (prod_id) REFERENCES Products (prod_id);
ALTER TABLE Orders ADD CONSTRAINT FK_Orders_Customers FOREIGN KEY (cust_id) REFERENCES Customers (cust_id);
ALTER TABLE Products ADD CONSTRAINT FK_Products_Vendors FOREIGN KEY (vend_id) REFERENCES Vendors (vend_id);

3.3 插入數據

  • Customers表
INSERT INTO Customers(cust_id, cust_name, cust_address, cust_city, cust_state, cust_zip, cust_country, cust_contact, cust_email)
VALUES('1000000001', 'Village Toys', '200 Maple Lane', 'Detroit', 'MI', '44444', 'USA', 'John Smith', '[email protected]');
INSERT INTO Customers(cust_id, cust_name, cust_address, cust_city, cust_state, cust_zip, cust_country, cust_contact)
VALUES('1000000002', 'Kids Place', '333 South Lake Drive', 'Columbus', 'OH', '43333', 'USA', 'Michelle Green');
INSERT INTO Customers(cust_id, cust_name, cust_address, cust_city, cust_state, cust_zip, cust_country, cust_contact, cust_email)
VALUES('1000000003', 'Fun4All', '1 Sunny Place', 'Muncie', 'IN', '42222', 'USA', 'Jim Jones', '[email protected]');
INSERT INTO Customers(cust_id, cust_name, cust_address, cust_city, cust_state, cust_zip, cust_country, cust_contact, cust_email)
VALUES('1000000004', 'Fun4All', '829 Riverside Drive', 'Phoenix', 'AZ', '88888', 'USA', 'Denise L. Stephens', '[email protected]');
INSERT INTO Customers(cust_id, cust_name, cust_address, cust_city, cust_state, cust_zip, cust_country, cust_contact)
VALUES('1000000005', 'The Toy Store', '4545 53rd Street', 'Chicago', 'IL', '54545', 'USA', 'Kim Howard');
  • Vendors表
INSERT INTO Vendors(vend_id, vend_name, vend_address, vend_city, vend_state, vend_zip, vend_country)
VALUES('BRS01','Bears R Us','123 Main Street','Bear Town','MI','44444', 'USA');
INSERT INTO Vendors(vend_id, vend_name, vend_address, vend_city, vend_state, vend_zip, vend_country)
VALUES('BRE02','Bear Emporium','500 Park Street','Anytown','OH','44333', 'USA');
INSERT INTO Vendors(vend_id, vend_name, vend_address, vend_city, vend_state, vend_zip, vend_country)
VALUES('DLL01','Doll House Inc.','555 High Street','Dollsville','CA','99999', 'USA');
INSERT INTO Vendors(vend_id, vend_name, vend_address, vend_city, vend_state, vend_zip, vend_country)
VALUES('FRB01','Furball Inc.','1000 5th Avenue','New York','NY','11111', 'USA');
INSERT INTO Vendors(vend_id, vend_name, vend_address, vend_city, vend_state, vend_zip, vend_country)
VALUES('FNG01','Fun and Games','42 Galaxy Road','London', NULL,'N16 6PS', 'England');
INSERT INTO Vendors(vend_id, vend_name, vend_address, vend_city, vend_state, vend_zip, vend_country)
VALUES('JTS01','Jouets et ours','1 Rue Amusement','Paris', NULL,'45678', 'France');
  • Products表
INSERT INTO Products(prod_id, vend_id, prod_name, prod_price, prod_desc)
VALUES('BR01', 'BRS01', '8 inch teddy bear', 5.99, '8 inch teddy bear, comes with cap and jacket');
INSERT INTO Products(prod_id, vend_id, prod_name, prod_price, prod_desc)
VALUES('BR02', 'BRS01', '12 inch teddy bear', 8.99, '12 inch teddy bear, comes with cap and jacket');
INSERT INTO Products(prod_id, vend_id, prod_name, prod_price, prod_desc)
VALUES('BR03', 'BRS01', '18 inch teddy bear', 11.99, '18 inch teddy bear, comes with cap and jacket');
INSERT INTO Products(prod_id, vend_id, prod_name, prod_price, prod_desc)
VALUES('BNBG01', 'DLL01', 'Fish bean bag toy', 3.49, 'Fish bean bag toy, complete with bean bag worms with which to feed it');
INSERT INTO Products(prod_id, vend_id, prod_name, prod_price, prod_desc)
VALUES('BNBG02', 'DLL01', 'Bird bean bag toy', 3.49, 'Bird bean bag toy, eggs are not included');
INSERT INTO Products(prod_id, vend_id, prod_name, prod_price, prod_desc)
VALUES('BNBG03', 'DLL01', 'Rabbit bean bag toy', 3.49, 'Rabbit bean bag toy, comes with bean bag carrots');
INSERT INTO Products(prod_id, vend_id, prod_name, prod_price, prod_desc)
VALUES('RGAN01', 'DLL01', 'Raggedy Ann', 4.99, '18 inch Raggedy Ann doll');
INSERT INTO Products(prod_id, vend_id, prod_name, prod_price, prod_desc)
VALUES('RYL01', 'FNG01', 'King doll', 9.49, '12 inch king doll with royal garments and crown');
INSERT INTO Products(prod_id, vend_id, prod_name, prod_price, prod_desc)
VALUES('RYL02', 'FNG01', 'Queen doll', 9.49, '12 inch queen doll with royal garments and crown');

  • Orders表
INSERT INTO Orders(order_num, order_date, cust_id)
VALUES(20005, '2012-05-01', '1000000001');
INSERT INTO Orders(order_num, order_date, cust_id)
VALUES(20006, '2012-01-12', '1000000003');
INSERT INTO Orders(order_num, order_date, cust_id)
VALUES(20007, '2012-01-30', '1000000004');
INSERT INTO Orders(order_num, order_date, cust_id)
VALUES(20008, '2012-02-03', '1000000005');
INSERT INTO Orders(order_num, order_date, cust_id)
VALUES(20009, '2012-02-08', '1000000001');
  • OrderItems表
INSERT INTO OrderItems(order_num, order_item, prod_id, quantity, item_price)
VALUES(20005, 1, 'BR01', 100, 5.49);
INSERT INTO OrderItems(order_num, order_item, prod_id, quantity, item_price)
VALUES(20005, 2, 'BR03', 100, 10.99);
INSERT INTO OrderItems(order_num, order_item, prod_id, quantity, item_price)
VALUES(20006, 1, 'BR01', 20, 5.99);
INSERT INTO OrderItems(order_num, order_item, prod_id, quantity, item_price)
VALUES(20006, 2, 'BR02', 10, 8.99);
INSERT INTO OrderItems(order_num, order_item, prod_id, quantity, item_price)
VALUES(20006, 3, 'BR03', 10, 11.99);
INSERT INTO OrderItems(order_num, order_item, prod_id, quantity, item_price)
VALUES(20007, 1, 'BR03', 50, 11.49);
INSERT INTO OrderItems(order_num, order_item, prod_id, quantity, item_price)
VALUES(20007, 2, 'BNBG01', 100, 2.99);
INSERT INTO OrderItems(order_num, order_item, prod_id, quantity, item_price)
VALUES(20007, 3, 'BNBG02', 100, 2.99);
INSERT INTO OrderItems(order_num, order_item, prod_id, quantity, item_price)
VALUES(20007, 4, 'BNBG03', 100, 2.99);
INSERT INTO OrderItems(order_num, order_item, prod_id, quantity, item_price)
VALUES(20007, 5, 'RGAN01', 50, 4.49);
INSERT INTO OrderItems(order_num, order_item, prod_id, quantity, item_price)
VALUES(20008, 1, 'RGAN01', 5, 4.99);
INSERT INTO OrderItems(order_num, order_item, prod_id, quantity, item_price)
VALUES(20008, 2, 'BR03', 5, 11.99);
INSERT INTO OrderItems(order_num, order_item, prod_id, quantity, item_price)
VALUES(20008, 3, 'BNBG01', 10, 3.49);
INSERT INTO OrderItems(order_num, order_item, prod_id, quantity, item_price)
VALUES(20008, 4, 'BNBG02', 10, 3.49);
INSERT INTO OrderItems(order_num, order_item, prod_id, quantity, item_price)
VALUES(20008, 5, 'BNBG03', 10, 3.49);
INSERT INTO OrderItems(order_num, order_item, prod_id, quantity, item_price)
VALUES(20009, 1, 'BNBG01', 250, 2.49);
INSERT INTO OrderItems(order_num, order_item, prod_id, quantity, item_price)
VALUES(20009, 2, 'BNBG02', 250, 2.49);
INSERT INTO OrderItems(order_num, order_item, prod_id, quantity, item_price)
VALUES(20009, 3, 'BNBG03', 250, 2.49);

好了,到目前爲止我們後續練習需要用到的數據庫、表已經創建完畢,併成功插入數據。

後面系列筆記的全部練習全部基於本部分創建的數據庫進行。


參考資料:
1.《SQL必知必會》Ben Forta。

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