1. 程式人生 > >MYSQL基礎加固——創建數據庫並插入數據

MYSQL基礎加固——創建數據庫並插入數據

小寫 get ice log number 區分 start 浮點數 text

二、開發準備

在使用實驗樓 Linux 環境進行本次實驗之前,先用以下兩條命令打開MySQL 服務並使用 root 登錄:

# 打開 MySQL 服務
sudo service mysql start        

#使用 root 用戶登錄,密碼為空
mysql -u root                   

後續的實驗都在 MySQL 的控制臺輸入命令進行操作。

三、實驗步驟

3.1 新建數據庫

首先,我們創建一個數據庫,給它一個名字,比如 mysql_shiyan,以後的幾次實驗也是對 mysql_shiyan 這個數據庫進行操作。 語句格式為 CREATE DATABASE <數據庫名字>;

,(註意不要漏掉分號 ;),前面的 CREATE DATABASE 也可以使用小寫,具體命令為:

CREATE DATABASE mysql_shiyan;

創建成功後輸入命令 show databases; (註意不要漏掉;)檢查一下:

技術分享圖片

在大多數系統中,SQL 語句都是不區分大小寫的,因此以下語句都是合法的:

CREATE DATABASE name1;
create database name2;
CREATE database name3;
create DAtabaSE name4;

但是出於嚴謹,而且便於區分保留字(保留字(reserved word):指在高級語言中已經定義過的字,使用者不能再將這些字作為變量名或過程名使用。

)和變量名,我們把保留字大寫,把變量和數據小寫。

3.2 連接數據庫

接下來的操作,就在剛才創建的 mysql_shiyan 中進行,首先要連接數據庫,使用語句 use <數據庫名字>

use mysql_shiyan;

如圖顯示,則連接成功:

技術分享圖片

輸入命令 show tables; 可以查看當前數據庫裏有幾張表,現在mysql_shiyan裏還是空的:

技術分享圖片

3.3 數據表

數據表(table)簡稱表,它是數據庫最重要的組成部分之一。數據庫只是一個框架,表才是實質內容。

而一個數據庫中一般會有多張表,這些各自獨立的表通過建立關系被聯接起來,才成為可以交叉查閱、一目了然的數據庫。如下便是一張表:

IDnamephone
01 Tom 110110110
02 Jack 119119119
03 Rose 114114114

3.4 新建數據表

在數據庫中新建一張表的語句格式為:

CREATE TABLE 表的名字
(
列名a 數據類型(數據長度),
列名b 數據類型(數據長度),
列名c 數據類型(數據長度)
);

我們嘗試在 mysql_shiyan 中新建一張表 employee,包含姓名,ID 和電話信息,所以語句為:

CREATE TABLE employee (id int(10),name char(20),phone int(12));

然後再創建一張表 department,包含名稱和電話信息,想讓命令看起來更整潔,你可以這樣輸入命令:

技術分享圖片

這時候再 show tables; 一下,可以看到剛才添加的兩張表:

技術分享圖片

3.5 數據類型

在剛才新建表的過程中,我們提到了數據類型,MySQL 的數據類型和其他編程語言大同小異,下表是一些 MySQL 常用數據類型:

數據類型大小(字節)用途格式
INT 4 整數
FLOAT 4 單精度浮點數
DOUBLE 8 雙精度浮點數
ENUM 單選,比如性別 ENUM(‘a‘,‘b‘,‘c‘)
SET 多選 SET(‘1‘,‘2‘,‘3‘)
DATE 3 日期 YYYY-MM-DD
TIME 3 時間點或持續時間 HH:MM:SS
YEAR 1 年份值 YYYY
CHAR 0~255 定長字符串
VARCHAR 0~255 變長字符串
TEXT 0~65535 長文本數據

整數除了 INT 外,還有 TINYINT、SMALLINT、MEDIUMINT、BIGINT。

CHAR 和 VARCHAR 的區別: CHAR 的長度是固定的,而 VARCHAR 的長度是可以變化的,比如,存儲字符串 “abc",對於 CHAR(10),表示存儲的字符將占 10 個字節(包括 7 個空字符),而同樣的 VARCHAR(12) 則只占用4個字節的長度,增加一個額外字節來存儲字符串本身的長度,12 只是最大值,當你存儲的字符小於 12 時,按實際長度存儲。

ENUM和SET的區別: ENUM 類型的數據的值,必須是定義時枚舉的值的其中之一,即單選,而 SET 類型的值則可以多選。

想要了解更多關於 MySQL 數據類型的信息,可以參考下面兩篇博客。

  • MySQL 中的數據類型介紹
  • MySQL 數據類型

3.6 插入數據

剛才我們新建了兩張表,使用語句 SELECT * FROM employee; 查看表中的內容,可以看到 employee 表中現在還是空的:

技術分享圖片

剛才使用的SELECT語句將在下一節實驗中詳細介紹

我們通過 INSERT 語句向表中插入數據,語句格式為:

INSERT INTO 表的名字(列名a,列名b,列名c) VALUES(值1,值2,值3);

我們嘗試向 employee 中加入 Tom、Jack 和 Rose:

INSERT INTO employee(id,name,phone) VALUES(01,‘Tom‘,110110110);

INSERT INTO employee VALUES(02,‘Jack‘,119119119);

INSERT INTO employee(id,name) VALUES(03,‘Rose‘);

你已經註意到了,有的數據需要用單引號括起來,比如 Tom、Jack、Rose 的名字,這是由於它們的數據類型是 CHAR 型。此外 VARCHAR,TEXT,DATE,TIME,ENUM 等類型的數據也需要單引號修飾,而 INT,FLOAT,DOUBLE 等則不需要。

第一條語句比第二條語句多了一部分:(id,name,phone) 這個括號裏列出的,是將要添加的數據 (01,‘Tom‘,110110110) 其中每個值在表中對應的列。而第三條語句只添加了 (id,name) 兩列的數據,所以在表中Rose的phone為NULL。

現在我們再次使用語句 SELECT * FROM employee; 查看 employee 表,可見 Tom 和 Jack 的相關數據已經保存在其中了:

技術分享圖片

四、實驗總結

經過本次實驗,我們已經有了一個名為 mysql_shiyan 的數據庫,其中有兩張表,我們已經向其中插入了一些數據。務必完整地操作一遍,以熟練SQL語句的使用。下一節我們將進入 SQL 約束的學習。

MYSQL基礎加固——創建數據庫並插入數據