<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                企業??AI智能體構建引擎,智能編排和調試,一鍵部署,支持知識庫和私有化部署方案 廣告
                # MySQL 數據類型 > 原文: [http://zetcode.com/databases/mysqltutorial/datatypes/](http://zetcode.com/databases/mysqltutorial/datatypes/) 在 MySQL 教程的這一部分中,我們介紹了 MySQL 數據類型。 數據類型是一組可表示的值。 每個值都屬于一種數據類型。 可以通過名稱引用的項目,例如 SQL 參數,列,字段,屬性和變量,也具有聲明的類型。 MySQL 支持以下數據類型組: * [數值](#numbers) * [日期&時間](#datetime) * [字符串](#strings) * [JSON](#json) 為列選擇正確的數據類型是數據庫初始設計的一部分。 數據類型可確保所提供數據的正確性。 他們確保以有意義的方式使用數據。 當我們進行比較,數據排序時,這一點很重要。 例如,日期比較與數字比較不同。 使用我們的表的其他開發者將知道期望從數據庫架構中獲取哪些數據。 數據類型使 MySQL 可以對插入的數據進行驗證。 最后,使用正確的表列數據類型,我們允許 MySQL 優化查詢并使用更少的磁盤空間。 ## 數字 數值類型可以是整數,也可以是浮點數。 1. 整數 1. 天音 2. SMALLINT 3. 中號 4. 整數 5. 比金特 2. 浮點數 1. 浮動 2. 雙 3. 十進制 ### 整數 整數是實數的子集。 它們寫時沒有小數或小數部分。 整數落入集合`Z = {..., -2, -1, 0, 1, 2, ......}`中,整數是無限的。 實際上,計算機只能使用整數值的子集,因為計算機的容量有限。 整數用于計算離散實體。 我們可以有 3、4、6 輛車,但不能有 3.33 輛車。 我們可以有 3.33 公斤。 以下是 MySQL 中整數類型的表:`TINYINT`,`MEDIUMINT`和`BIGINT`是 SQL 標準的 MySQL 擴展。 Table 1: Signed integer types | 數據類型 | 字節數 | 最小值 | 最大值 | | --- | --- | --- | --- | | `TINYINT` | 1 | -128 | 127 | | `SMALLINT` | 2 | -32768 | 32767 | | `MEDIUM` | 3 | -8388608 | 8388607 | | `INT` | 4 | -2147483648 | 2147483647 | | `BIGINT` | 8 | -9223372036854775808 | 9223372036854775807 | 整數類型的存儲方式不同。 我們可以選擇符合我們要求的值。 ```sql mysql> CREATE TABLE Ages(Id SMALLINT, Age TINYINT) ENGINE=Memory; ``` 我們已經創建了一個臨時的`Ages`表。 這只是一個臨時測試表,因此只有幾行。 `SMALLINT`就足夠了。 我們不認識任何年齡超過 130 歲的人,因此`Age`列可以使用`TINYINT`。 ```sql mysql> INSERT INTO Ages VALUES(1, 43); Query OK, 1 row affected (0.00 sec) ``` 我們在表中插入一行。 ```sql mysql> INSERT INTO Ages VALUES (2, 128); ERROR 1264 (22003): Out of range value for column 'Age' at row 1 ``` 嘗試插入列類型范圍之外的值會導致錯誤。 當我們處理年齡時,我們不需要負整數值。 MySQL 支持無符號整數。 這樣,我們可以進一步優化表定義。 Table 2: Unsigned integer types | 數據類型 | 字節數 | 最小值 | 最大值 | | --- | --- | --- | --- | | `TINYINT` | 1 個 | 0 | 255 | | `SMALLINT` | 2 | 0 | 65535 | | `MEDIUM` | 3 | 0 | 16777215 | | `INT` | 4 | 0 | 4294967295 | | `BIGINT` | 8 | 0 | 18446744073709551615 | 我們使用 SQL 語句將`Age`列更改為具有`TINYINT UNSIGNED`數據類型。 ```sql mysql> ALTER TABLE Ages MODIFY Age TINYINT UNSIGNED; ``` 現在我們可以插入 0 到 255 之間的值。 ```sql mysql> INSERT INTO Ages VALUES(2, 128); Query OK, 1 row affected (0,00 sec) mysql> SELECT * FROM Ages; +------+------+ | ID | Age | +------+------+ | 1 | 43 | | 2 | 128 | +------+------+ 2 rows in set (0,00 sec) ``` 我們插入了一個假設的年齡 128。現在該列接受它。 ### 浮點值 浮點數表示計算中的實數。 實數測量連續的量,例如重量,高度或速度。 MySQL 具有用于近似值的浮點類型:`FLOAT`和`DOUBLE`和用于精確值的定點類型:`DECIMAL`和`NUMERIC`。 `FLOAT`是單精度浮點數。 MySQL 使用四個字節來存儲`FLOAT`值。 `DOUBLE`是雙精度浮點數。 MySQL 使用八個字節來存儲`DOUBLE`值。 MySQL 將`DOUBLE`視為`DOUBLE PRECISION`(非標準擴展名)的同義詞。 另外,除非啟用`REAL_AS_FLOAT` SQL 模式,否則 MySQL 還將`REAL`視為`DOUBLE PRECISION`的同義詞。 `DECIMAL`和`NUMERIC`類型存儲精確的數值數據值。 當保留精確度非常重要時,例如使用貨幣數據,則使用這些類型。 在 MySQL 中,`NUMERIC`是`DECIMAL`的同義詞。 浮點數,雙精度數和小數可能已指定其精度和小數位數。 在`DECIMAL[M, D]`中,`M`是最大位數,即精度。 `D`是小數點右邊的位數。 它是規模。 如果您有一列帶有`DECIMAL(3, 1)`的列,則可以插入最多三位數的數字:小數點之前和之后的`wwo`。 ```sql mysql> SELECT 1/3; +--------+ | 1/3 | +--------+ | 0.3333 | +--------+ 1 row in set (0,00 sec) mysql> SELECT 0.3333 = 1/3; +--------------+ | 0.3333 = 1/3 | +--------------+ | 0 | +--------------+ 1 row in set (0,00 sec) ``` 您可能希望第二條 SQL 語句中的比較返回`true`,但事實并非如此。 原因是如何存儲浮點值。 使用浮點值時必須格外小心。 浮點數和雙精度詞處理起來更快,但它們到最后一位數字不準確。 舍入誤差很小,在許多情況下都可以。 在許多真實的單詞情況下,我們只需要有一個近似值。 例如,您在一家商店里有 7.5321 公斤蘋果和 4.372 公斤橘子。 可以將這兩個值分別存儲為 7.5 kg 和 4.4 kg。 沒什么大不了。 另一方面,在精確的科學或貨幣計算中,需要高精度。 在這種情況下,我們使用`DECIMAL`數據類型。 ```sql mysql> CREATE TABLE Numbers (Id TINYINT, Floats FLOAT, Decimals DECIMAL(3, 2)); ``` 我們創建一個表,其中將存儲一些浮點數和小數。 ```sql mysql> INSERT INTO Numbers VALUES (1, 1.1, 1.1), (2, 1.1, 1.1), (3, 1.1, 1.1); ``` 我們將三行插入到新創建的表中。 ```sql mysql> SELECT * FROM Numbers; +------+--------+----------+ | Id | Floats | Decimals | +------+--------+----------+ | 1 | 1.1 | 1.10 | | 2 | 1.1 | 1.10 | | 3 | 1.1 | 1.10 | +------+--------+----------+ 3 rows in set (0,00 sec) ``` 這是表的外觀。 ```sql mysql> SELECT SUM(Floats), SUM(Decimals) FROM Numbers; +--------------------+---------------+ | SUM(Floats) | SUM(Decimals) | +--------------------+---------------+ | 3.3000000715255737 | 3.30 | +--------------------+---------------+ 1 row in set (0,08 sec) ``` 兩種結果不同。 十進制計算更精確。 由于一些內部舍入,浮點數的總和不準確。 ## 日期&時間值 MySQL 具有用于存儲日期和時間的數據類型:`DATE`,`TIME`,`DATETIME`,`YEAR`和`TIMESTAMP`。 MySQL 試圖以幾種格式解釋日期和時間值,但是日期部分必須始終以年/月/日的順序給出。 如果在數字上下文中使用日期或時間值,則 MySQL 自動將日期或時間值轉換為數字,反之亦然。 ### 日期 `DATE`用于存儲日期。 MySQL 檢索并以`YYYY-MM-DD`格式顯示日期值。 支持的范圍是`1000-01-01`至`9999-12-31`。 ```sql mysql> SELECT CURDATE(); +------------+ | CURDATE() | +------------+ | 2017-01-31 | +------------+ 1 row in set (0,00 sec) ``` `CURDATE()`函數返回當前日期。 ```sql mysql> SELECT DATE('2017-01-31 12:01:00'); +-----------------------------+ | DATE('2017-01-31 12:01:00') | +-----------------------------+ | 2017-01-31 | +-----------------------------+ 1 row in set (0,00 sec) ``` `DATE()`函數返回日期和時間值的日期部分。 ```sql mysql> SELECT ADDDATE('2017-01-20', 8); +--------------------------+ | ADDDATE('2017-01-20', 8) | +--------------------------+ | 2017-01-28 | +--------------------------+ 1 row in set (0,00 sec) ``` `ADDDATE()`函數將日期添加到日期。 它返回計算的日期。 ```sql mysql> CREATE TABLE Dates(Id TINYINT, Dates DATE); mysql> INSERT INTO Dates VALUES(1, '2017-01-24'); mysql> INSERT INTO Dates VALUES(2, '2017/01/25'); mysql> INSERT INTO Dates VALUES(3, '20170126'); mysql> INSERT INTO Dates VALUES(4, '170127'); mysql> INSERT INTO Dates VALUES(5, '2017+01+28'); ``` 日期在 MySQL 中以一種格式顯示,但是我們可以在 SQL 語句中使用各種日期格式。 `YYYY-MM-DD`是標準格式。 日期部分之間可以使用任何標點符號。 ```sql mysql> SELECT * FROM Dates; +------+------------+ | Id | Dates | +------+------------+ | 1 | 2017-01-24 | | 2 | 2017-01-25 | | 3 | 2017-01-26 | | 4 | 2017-01-27 | | 5 | 2017-01-28 | +------+------------+ 5 rows in set (0,00 sec) ``` 我們使用多種格式將日期插入表中。 MySQL 使用一種格式來顯示日期。 ```sql mysql> INSERT INTO Dates VALUES (6, '10000-01-01'); ERROR 1292 (22007): Incorrect date value: '10000-01-01' for column 'Dates' at row 1 ``` 如果我們超出了支持的日期值范圍,則會發生錯誤。 ### 時間 `TIME`數據類型用于在 MySQL 中顯示時間。 它以`HH:MM:SS`格式顯示值。 MySQL 檢索并以`'HH:MM:SS'`格式或`'HHH:MM:SS'`格式顯示`TIME`值以獲得較大的小時值。 范圍是從`-838:59:59`到`838:59:59`。 時間格式的小時部分可能大于 24。這是因為`TIME`數據類型可用于表示時間間隔。 這也是為什么我們可以使用負時間值的原因。 ```sql mysql> SELECT CURTIME(); +-----------+ | CURTIME() | +-----------+ | 11:47:36 | +-----------+ 1 row in set (0,00 sec) ``` `CURTIME()`函數返回當前時間。 ```sql mysql> SELECT TIMEDIFF('23:34:32', '22:00:00'); +----------------------------------+ | TIMEDIFF('23:34:32', '22:00:00') | +----------------------------------+ | 01:34:32 | +----------------------------------+ 1 row in set (0,02 sec) ``` `TIMEDIFF()`函數用于減去兩個時間值。 ```sql mysql> SELECT TIME('2017-01-31 11:06:43'); +-----------------------------+ | TIME('2017-01-31 11:06:43') | +-----------------------------+ | 11:06:43 | +-----------------------------+ 1 row in set (0,00 sec) ``` 我們可以使用`TIME()`函數提取日期和時間值的時間部分。 ```sql mysql> SELECT TIMEDIFF('211344', 201123); +----------------------------+ | TIMEDIFF('211344', 201123) | +----------------------------+ | 01:02:21 | +----------------------------+ 1 row in set (0,00 sec) ``` 我們也可以用不同的格式編寫時間值。 第一個參數是沒有分隔符的字符串格式的時間值。 第二個是指定為數字的時間值。 ### 時間日期 `DATETIME`值包含日期和時間。 MySQL 檢索并以`YYYY-MM-DD HH:MM:SS`格式顯示值。 支持的范圍是`1000-01-01 00:00:00`至`9999-12-31 23:59:59`。 ```sql mysql> SELECT NOW(); +---------------------+ | NOW() | +---------------------+ | 2017-01-31 11:57:53 | +---------------------+ 1 row in set (0,00 sec) ``` `NOW()`函數返回當前日期時間。 ```sql mysql> SELECT DAYNAME('2017@01@31 11@12@12'); +--------------------------------+ | DAYNAME('2017@01@31 11@12@12') | +--------------------------------+ | Tuesday | +--------------------------------+ 1 row in set (0,02 sec) ``` MySQL 僅以一種格式顯示日期和時間。 但是在我們的 SQL 語句中,我們可以使用不同的格式。 任何標點符號都可以用作日期部分或時間部分之間的分隔符。 在本例中,我們使用了`@`字符。 ### 年 `YEAR`是用于表示年份的數據類型。 MySQL 以`YYYY`格式顯示`YEAR`值。 它允許我們使用字符串或數字將值分配給`YEAR`列。 允許的范圍是 1901 至 2155,即 0000。非法年份值轉換為 0000。 ```sql mysql> SELECT YEAR(CURDATE()) AS 'Current year'; +--------------+ | Current year | +--------------+ | 2017 | +--------------+ 1 row in set (0,02 sec) ``` 在上面的 SQL 語句中,我們檢索了當年。 ### 時間戳 時間戳是一個字符序列,表示某個事件發生的日期和/或時間。 時間戳通常用于記錄事件。 在 MySQL 中,我們有`TIMESTAMP`數據類型用于創建時間戳。 `TIMESTAMP`列可用于記錄`INSERT`或`UPDATE`操作的日期和時間。 如果您自己沒有給它一個值,它將自動設置為最近一次操作的日期和時間。 `TIMESTAMP`數據類型的范圍為`1970-01-01 00:00:01` UTC 到`2038-01-19 03:14:07` UTC。 下表總結了支持的`TIMESTAMP`格式。 | 數據類型 | 格式 | | --- | --- | | `TIMESTAMP(14)` | `YYYYMMDDHHMMSS` | | `TIMESTAMP(12)` | `YYMMDDHHMMSS` | | `TIMESTAMP(10)` | `YYMMDDHHMM` | | `TIMESTAMP(8)` | `YYYYMMDD` | | `TIMESTAMP(6)` | `YYMMDD` | | `TIMESTAMP(4)` | `YYMM` | | `TIMESTAMP(2)` | `YY` | `TIMESTAMP`數據類型提供自動初始化和更新。 我們可以限制此數據類型為僅具有自動初始化或僅自動更新。 ```sql mysql> CREATE TABLE Prices(Id TINYINT PRIMARY KEY, Price DECIMAL(8, 2), Stamp TIMESTAMP); mysql> INSERT INTO Prices(Id, Price) VALUES(1, 234.34); mysql> INSERT INTO Prices(Id, Price) VALUES(2, 344.12); ``` 我們創建一個帶有`TIMESTAMP`列的表。 我們在表中插入兩行。 `Stamp`列不包含在 SQL 語句中。 MySQL 自動填充該列。 ```sql mysql> SELECT * FROM Prices; +----+--------+---------------------+ | Id | Price | Stamp | +----+--------+---------------------+ | 1 | 234.34 | 2017-01-31 12:12:25 | | 2 | 344.12 | 2017-01-31 12:15:10 | +----+--------+---------------------+ 2 rows in set (0,00 sec) ``` 兩行的時間戳已創建。 這是`TIMESTAMP`數據類型的自動初始化。 創建表時,可以通過`Stamp TIMESTAMP DEFAULT 0 ON UPDATE CURRENT_TIMESTAMP` SQL 代碼將其關閉。 ```sql mysql> UPDATE Prices SET Price=250.50 WHERE Id=1; ``` 我們執行 SQL 語句以更新第一行中的`Price`列。 ```sql mysql> SELECT * FROM Prices; +----+--------+---------------------+ | Id | Price | Stamp | +----+--------+---------------------+ | 1 | 250.50 | 2017-01-31 12:17:21 | | 2 | 344.12 | 2017-01-31 12:15:10 | +----+--------+---------------------+ 2 rows in set (0,00 sec) ``` 第一列的時間戳已更新。 如果要關閉`TIMESTAMP`的自動更新,則可以在創建表時使用`Stamp TIMESTAMP DEFAULT CURRENT_TIMESTAMP` SQL 代碼。 ## 字符串 MySQL 具有以下字符串數據類型: * `CHAR` * `VARCHAR` * `BINARY` * `VARBINARY` * `BLOB` * `TEXT` * `ENUM` * `SET` ### `CHAR` `CHAR`是固定長度的字符數據類型。 聲明的長度為`CHAR(x)`,其中`x`可以在 0 到 255 之間。`CHAR`始終為每個條目使用相同數量的存儲空間。 如果我們指定的項目短于聲明的長度,則該值將用空格右填充到指定的長度。 檢索值時,尾部空格將被刪除。 ```sql mysql> CREATE TABLE Chars(Id TINYINT PRIMARY KEY, Chars CHAR(3)); mysql> INSERT INTO Chars VALUES (1, 'a'), (2, 'ab'), (3, 'abc'), (4, 'abb'); ``` 在上面的 SQL 代碼中,我們創建了`Chars`表,該表具有`CHAR`數據類型的一列。 最大長度設置為三個字符。 ```sql mysql> INSERT INTO Chars VALUES (5, 'abcd'); ERROR 1406 (22001): Data too long for column 'Chars' at row 1 ``` 嘗試插入比指定長度更大的字符串會導致錯誤。 ```sql mysql> SELECT * FROM Chars; +------+-------+ | Id | Chars | +------+-------+ | 1 | a | | 2 | ab | | 3 | abc | | 4 | abb | +------+-------+ 4 rows in set (0,00 sec) ``` 這就是我們表中的內容。 ```sql mysql> SELECT Id, LENGTH(Chars) AS Length FROM Chars; +------+--------+ | Id | Length | +------+--------+ | 1 | 1 | | 2 | 2 | | 3 | 3 | | 4 | 3 | +------+--------+ 4 rows in set (0,00 sec) ``` 我們已經檢索了 ID 和插入字符的長度。 之前我們已經說過,字符以固定大小存儲。 為什么現在行的大小值不同? 我們希望每一行都包含 3 個字符。 原因是 MySQL 在數據檢索時會修剪`char`的空間。 通過將`sql_mode`設置為`PAD_CHAR_TO_FULL_LENGTH`,空格也會被修剪。 ```sql mysql> SET sql_mode = 'PAD_CHAR_TO_FULL_LENGTH'; Query OK, 0 rows affected, 1 warning (0,00 sec) mysql> SELECT Id, LENGTH(Chars) AS Length FROM Chars; +------+--------+ | Id | Length | +------+--------+ | 1 | 3 | | 2 | 3 | | 3 | 3 | | 4 | 3 | +------+--------+ 4 rows in set (0,00 sec) ``` 通過更改`sql_mode`,我們可以獲得預期的結果。 ### `VARCHAR` `VARCHAR`數據類型存儲可變長度的字符串。 字符串的長度可以在 0 到 65535 之間。`VARCHAR`值在存儲時不會被填充。 在存儲和檢索值時保留尾隨空格。 大多數較短的字符串數據類型都存儲在此數據類型中。 例如電子郵件,人員名稱,商品或地址。 ```sql mysql> CREATE TABLE FirstNames(Id TINYINT, Firstname VARCHAR(20)); mysql> INSERT INTO FirstNames VALUES (1, 'Tom'), (2, 'Lucy'), (3, 'Alice'), -> (4, 'Robert'), (5, 'Timothy'), (6, 'Alexander'); ``` 我們創建一個`FirstNames`表,其中存儲六個名字。 ```sql mysql> SELECT Id, LENGTH(FirstName) AS Length FROM FirstNames; +------+--------+ | Id | Length | +------+--------+ | 1 | 3 | | 2 | 4 | | 3 | 5 | | 4 | 6 | | 5 | 7 | | 6 | 9 | +------+--------+ 6 rows in set (0,00 sec) ``` 我們可以看到`VARCHAR`列類型的名稱以可變長度存儲。 這樣可以節省磁盤空間。 ### `BINARY`和`VARBINARY` `BINARY`和`VARBINARY`是二進制字節數據類型。 它們包含字節字符串而不是字符串。 他們沒有字符集。 排序和比較基于值中字節的數字值。 `BINARY`數據類型的范圍是 0 到 255。它以固定長度存儲值。 `VARBINARY`的范圍是 0 到 65535。 ### `BLOB` `BLOB`是二進制大對象數據類型。 它可以保存可變數量的二進制數據。 它可以用于存儲圖像或文檔等二進制數據。 `BLOB`有四種類型: | `BLOB`類型 | 范圍(以字節為單位) | | --- | --- | | `TINYBLOB` | 0-255 | | `BLOB` | 0-65535 | | `MEDIUMBLOB` | 0-16777215 | | `LONGBLOB` | 0-4294967295 | 接下來,我們將讀取和寫入圖像。 ```sql mysql> CREATE TABLE Images(Id INT PRIMARY KEY, Img LONGBLOB); ``` 創建帶有`LONGBLOB`列的表。 ```sql mysql> SHOW VARIABLES LIKE "secure_file_priv"; +------------------+-----------------------+ | Variable_name | Value | +------------------+-----------------------+ | secure_file_priv | /var/lib/mysql-files/ | +------------------+-----------------------+ 1 row in set (0,02 sec) ``` MySQL 在加載和轉儲數據方面有安全限制。 `secure_file_priv`顯示允許進行此類操作的目錄路徑。 ```sql mysql> INSERT INTO Images VALUES (1, LOAD_FILE('/var/lib/mysql-files/image1.jpg')); ``` 借助`LOAD_FILE()`函數,我們將圖像插入`Images`表。 ```sql mysql> SELECT Img FROM Images WHERE Id=1 INTO DUMPFILE '/var/lib/mysql-files/image_bck.jpg'; ``` 我們從表中選擇圖像并將其寫入`/var/lib/mysql-files`目錄中的文件。 ```sql $ sudo ls /var/lib/mysql-files/ -l total 608 -rw-r--r-- 1 root root 309262 jan 31 13:08 image1.jpg -rw-rw-rw- 1 mysql mysql 309262 jan 31 13:12 image_bck.jpg ``` 現在,我們應該在目錄中擁有這兩個文件。 ### `TEXT` `TEXT`數據類型用于存儲大型文本數據。 例如文章,博客或頁面。 當`VARCHAR`和其他基于字符串的數據對象不足以處理所需信息量的存儲時,最好使用`TEXT`值。 | 文本類型 | 范圍(以字節為單位) | | --- | --- | | `TINYTEXT` | 0-255 | | `TEXT` | 0-65535 | | `MEDIUMTEXT` | 0-16777215 | | `LONGTEXT` | 0-4294967295 | 插入時沒有填充,選擇時也不會刪除字節。 ### `ENUM` `ENUM`是一個字符串對象,其值是從允許的值列表中選擇的。 在列規范中明確枚舉了它們。 我們只能從列表中插入一個值。 ```sql mysql> CREATE TABLE Sizes(Size ENUM('S', 'M', 'L', 'XL', 'XXL')); ``` 我們創建一個表,該表具有`ENUM`類型的一列。 明確列出了允許值的列表。 ```sql mysql> INSERT INTO SizeTable VALUES ('S'), ('L'); ``` 我們在表中插入兩行。 ```sql mysql> INSERT INTO Sizes VALUES ('Large'); ERROR 1265 (01000): Data truncated for column 'Size' at row 1 ``` 由于列表中未提及`'Large'`,因此我們會收到一條錯誤消息。 ```sql mysql> SELECT * FROM Sizes; +------+ | Size | +------+ | S | | L | +------+ 2 rows in set (0,00 sec) ``` 該表中有兩個常規值。 ### `SET` `SET`是一個字符串對象,可以具有零個或多個值,每個值都必須從允許值列表中選擇。 它類似于`ENUM`數據類型。 不同之處在于,它可以包含允許值列表中的零個或多個值。 ```sql mysql> CREATE TABLE Letters(Let SET('a', 'b', 'c', 'd', 'e')); ``` 我們創建一個允許在列上使用一組字母的表。 ```sql mysql> INSERT INTO Letters VALUES ('a'); mysql> INSERT INTO Letters VALUES ('b'); mysql> INSERT INTO Letters VALUES ('b,a'); mysql> INSERT INTO Letters VALUES (''); mysql> INSERT INTO Letters VALUES ('a,b,c'); mysql> SELECT * FROM Letters; +-------+ | Let | +-------+ | a | | b | | a,b | | | | a,b,c | +-------+ 5 rows in set (0,00 sec) ``` 我們添加了`SET`允許的各種字母組合。 ## JSON 格式 從 MySQL 5.7.8 開始,MySQL 支持本機 JSON 數據類型。 JSON(JavaScript 對象表示法)是一種輕量級的數據交換格式。 人類很容易讀寫,機器也很容易解析和生成。 MySQL 自動驗證存儲在 JSON 列中的 JSON 文檔。 無效的文檔會產生錯誤。 存儲在 JSON 列中的 JSON 文檔已經過優化,可實現高效訪問。 JSON 列不能具有默認值。 ```sql mysql> CREATE TABLE t1 (Doc JSON); ``` 創建帶有`JSON`列的表。 ```sql mysql> INSERT INTO t1 VALUES('{"chair": "5", "table": "4", "lamp": "6"}'); ``` 將文檔添加到表中。 ```sql mysql> SELECT * FROM t1; +-------------------------------------------+ | Doc | +-------------------------------------------+ | {"lamp": "6", "chair": "5", "table": "4"} | +-------------------------------------------+ 1 row in set (0,00 sec) ``` 我們顯示表的內容。 ```sql mysql> SELECT JSON_ARRAY('pen', 4, 'pencil', 2, 'rubber', 1); +------------------------------------------------+ | JSON_ARRAY('pen', 4, 'pencil', 2, 'rubber', 1) | +------------------------------------------------+ | ["pen", 4, "pencil", 2, "rubber", 1] | +------------------------------------------------+ 1 row in set (0,02 sec) ``` `JSON_ARRAY()`函數獲取值列表,并將其轉換為 JSON 數組。 ```sql mysql> SELECT JSON_OBJECT('pen', 4, 'pencil', 2, 'rubber', 1); +-------------------------------------------------+ | JSON_OBJECT('pen', 4, 'pencil', 2, 'rubber', 1) | +-------------------------------------------------+ | {"pen": 4, "pencil": 2, "rubber": 1} | +-------------------------------------------------+ 1 row in set (0,00 sec) ``` `JSON_OBJECT()`函數獲取鍵/值對的列表,然后返回包含這些對的 JSON 對象。 MySQL 教程的這一部分專門針對 MySQL 數據類型。
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看