婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 實例測試MySQL的enum類型

實例測試MySQL的enum類型

熱門標簽:電銷機器人好品牌門薩維l 中科嘉智人工智能電銷機器人 哈爾濱crm外呼系統價格 上海智能外呼系統需要多少錢 凱立德科技館地圖標注 做地圖標注都需要什么工具 甘孜電話機器人廠家 西安400電話在哪里辦理 銀川電銷外呼系統定制

在開發項目時通常會遇到一些狀態字段,例如訂單的狀態有 待支付、已支付、已關閉、已退款 等,我以前做的項目都是把這些狀態用數字存在數據庫中,然后在 php 代碼中用常量來維護一份映射表,例如:

const STATUS_PENDING = 0;
const STATUS_PAID = 1;
const STATUS_CLOSED = 2;
const STATUS_REFUNDED = 3;

但是在實際使用過程中發現并不是那么好用,由于各種原因(追查 bug、臨時的統計需求等)我們常常需要登錄到 mysql 服務器里手動執行一些 sql 查詢,由于許多表都有狀態字段,寫 sql 時必須對照的 php 代碼里的映射關系來寫,一不小心還有可能將不同表的狀態數字弄混導致大問題。

于是我在新項目中準備使用 mysql 的 enum 類型來存儲各種狀態,在使用過程中發現如果在 Laravel 的 migration 文件中對使用了 enum 類型的表做變更(即使是變更非 enum 類型的字段)都會報錯

[Doctrine\DBAL\DBALException]
Unknown database type enum requested, Doctrine\DBAL\Platforms\MySQL57Platform may not support it.

搜索了一下,發現是 doctrine 不支持 mysql 的 enum,該文中列舉了 enum 的 3 個缺點:

新增 enum 值的時候需要重建整個表,當數據量大的時候可能需要耗費數小時。

enum 值的排序規則是按創建表結構時指定的順序,而非字面值的大小。

依賴 mysql 對 enum 值的校驗并不是非常必要,在默認配置下插入非法值最終會變成空值。

根據新項目的實際情況,不太可能出現需要對狀態字段做排序的需求,即使有我們可以在設計表結構的時候就定好順序,因此缺點 2 可以忽略;而缺點 3 則可以通過代碼規范、插入/更新前校驗等方式來規避;至于缺點 1,我們需要做一些測試。

測試準備#

首先創建一個表:

CREATE TABLE `enum_tests` (
 `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
 `status` enum('pending','success','closed') COLLATE utf8mb4_unicode_ci NOT NULL,
 PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;

然后插入 100W 條數據:

$count = 1000000;
$bulk = 1000;
$data = [];
foreach (['pending', 'success', 'closed'] as $status) {
  $data[$status] = [];
  for ($i = 0; $i  $bulk; $i++) {
    $data[$status][] = ['status' => $status];
  }
}

for ($i = 0; $i  $count; $i += $bulk) {
  $status = array_random(['pending', 'success', 'closed']);
  EnumTest::insert($data[$status]);
}

測試過程#

測試1#

在 enum 值列表最后添加一個值 refunded

ALTER TABLE `enum_tests` CHANGE `status` `status` ENUM('pending','success','closed','refunded') CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL;

輸出:

Query OK, 0 rows affected (0.04 sec)
Records: 0 Duplicates: 0 Warnings: 0

結論:在末尾追加 enum 值時幾乎沒有成本。

測試 2:#

刪除剛剛添加的值 refunded

ALTER TABLE `enum_tests` CHANGE `status` `status` ENUM('pending','success','closed') CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL;

輸出:

Query OK, 1000000 rows affected (5.93 sec)
Records: 1000000 Duplicates: 0 Warnings: 0

結論:刪除一個沒有用過的 enum 值仍需全表掃描,成本較高,但還在可接受范圍內。

測試 3:#

將 refunded 插入到值列表中間而非末尾

ALTER TABLE `enum_tests` CHANGE `status` `status` ENUM('pending','success','refunded', 'closed') CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL;

輸出:

Query OK, 1000000 rows affected (6.00 sec)
Records: 1000000 Duplicates: 0 Warnings: 0

結論:在原 enum 值列表中間新增值需要全表掃描并更新,成本較高。

測試 4:#

刪除值列表中間的值

ALTER TABLE `enum_tests` CHANGE `status` `status` ENUM('pending','success','closed') CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL;

輸出:

Query OK, 1000000 rows affected (4.23 sec)
Records: 1000000 Duplicates: 0 Warnings: 0

結論:需全表掃描,成本較高。

測試 5:#

給 status 字段添加索引后再執行上述測試

ALTER TABLE `enum_tests` ADD INDEX(`status`);

發現測試 2-4 的耗時反而有所增加,應該是同時需要更新索引導致的。

結語:#

對于我的新項目來說只會出現新增 enum 值的情況,即使將來有個別狀態廢棄不用也不需要去調整 enum 的值列表,因此決定在項目中引入 enum 類型作為存儲狀態的數據類型。

標簽:浙江 那曲 濮陽 山南 安康 四川 安徽 平頂山

巨人網絡通訊聲明:本文標題《實例測試MySQL的enum類型》,本文關鍵詞  實例,測試,MySQL,的,enum,類型,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《實例測試MySQL的enum類型》相關的同類信息!
  • 本頁收集關于實例測試MySQL的enum類型的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    亚洲精品高清视频在线观看| 2022国产精品视频| 欧美日本视频在线| 国产亚洲精品中文字幕| 日韩黄色一级片| 欧美日韩一本到| 一区二区三区**美女毛片| 一本大道久久精品懂色aⅴ| 欧美国产亚洲另类动漫| jlzzjlzz欧美大全| 亚洲乱码一区二区三区在线观看| 成人晚上爱看视频| 综合激情网...| 成人精品视频一区| 亚洲欧美另类久久久精品2019| 亚洲免费伊人电影| 欧美中文字幕一区| 美女网站在线免费欧美精品| 日韩欧美一级特黄在线播放| 国产精品久久久久久妇女6080 | 精品国产伦一区二区三区观看体验| 无吗不卡中文字幕| 亚洲精品一区二区三区福利| 国产一区久久久| 欧美成人免费网站| 国产美女视频一区| 亚洲欧美福利一区二区| 555夜色666亚洲国产免| 国产福利一区在线| 亚洲主播在线观看| 91麻豆精品国产91久久久使用方法 | 五月天亚洲婷婷| 日韩欧美高清一区| 国产精品一区在线| 一区二区三区四区视频精品免费 | 伊人夜夜躁av伊人久久| 欧美日韩综合在线免费观看| 亚洲午夜电影网| 日韩欧美国产电影| 91在线精品一区二区三区| 五月激情综合婷婷| 国产精品毛片无遮挡高清| 欧美午夜电影一区| 成人久久视频在线观看| 亚洲免费高清视频在线| 99国产精品视频免费观看| 亚洲成人资源在线| 久久久久亚洲蜜桃| 欧美乱妇15p| 高清beeg欧美| 欧美aaaaaa午夜精品| 亚洲欧美综合色| 成人免费视频在线观看| 欧美图片一区二区三区| 久久精品国产一区二区三区免费看| 亚洲欧洲国产日本综合| 国产精品网站一区| 久久色在线视频| 日韩电影一区二区三区| 国产精品国产自产拍高清av王其| 日韩三级电影网址| 欧美精品九九99久久| 一本一本大道香蕉久在线精品| 久久99在线观看| 亚洲一级二级在线| 亚洲欧洲精品天堂一级| 国产精品另类一区| 欧美激情一区二区| 欧美国产禁国产网站cc| 久久久亚洲精品一区二区三区| 欧美一区日韩一区| 91精品国产丝袜白色高跟鞋| 这里只有精品99re| 欧美精品v国产精品v日韩精品 | 精品在线观看视频| 亚洲精品视频在线| 国产精品电影院| 亚洲精品一线二线三线| 天涯成人国产亚洲精品一区av| 国产精品久久久久久久久久免费看| 久久精品一区二区三区不卡牛牛 | 色婷婷久久综合| 高清久久久久久| 国产河南妇女毛片精品久久久| 伊人夜夜躁av伊人久久| 亚洲欧美一区二区三区极速播放 | 国产日本欧洲亚洲| 国产精品欧美一级免费| 久久综合色8888| 精品免费99久久| 视频一区在线视频| 麻豆一区二区99久久久久| 亚洲成人av福利| 青青草成人在线观看| 韩国午夜理伦三级不卡影院| 黄页视频在线91| 国产传媒欧美日韩成人| eeuss影院一区二区三区| 欧洲生活片亚洲生活在线观看| 欧美精品九九99久久| 精品国产一区久久| 亚洲精品国产精品乱码不99| 蜜臀av一区二区| 不卡的av电影在线观看| 精品视频色一区| 久久久精品综合| 亚洲国产日日夜夜| 久久噜噜亚洲综合| 亚洲免费av在线| 日韩精品亚洲专区| 国产精品正在播放| 色婷婷av一区二区三区软件| 欧美美女激情18p| 久久毛片高清国产| 亚洲一区中文在线| 国产精品一区二区免费不卡 | 国产成人av网站| 欧美视频中文字幕| 欧美日韩免费一区二区三区视频 | 欧美性受xxxx| 久久午夜色播影院免费高清| 国产精品白丝在线| 亚洲国产精品尤物yw在线观看| 久久99精品国产麻豆不卡| 色呦呦日韩精品| 日韩精品中文字幕一区二区三区 | 国产偷国产偷精品高清尤物| 亚洲精品高清视频在线观看| 国产精品亚洲成人| 欧美日韩中文国产| 亚洲色图丝袜美腿| 国产精品69毛片高清亚洲| 欧美日韩一区二区在线观看视频 | 成人污视频在线观看| 久久噜噜亚洲综合| 精品无人区卡一卡二卡三乱码免费卡| 欧洲国内综合视频| 国产精品初高中害羞小美女文| 激情五月播播久久久精品| 91精品国产综合久久久久久久久久 | 日韩一区二区在线观看| 一区二区三区四区中文字幕| 国产·精品毛片| 国产清纯白嫩初高生在线观看91| 亚洲国产精品人人做人人爽| 成人av网址在线| 国产精品传媒入口麻豆| 99久久久国产精品免费蜜臀| 国产精品欧美精品| 99久久婷婷国产综合精品 | 久久日一线二线三线suv| 蜜乳av一区二区| 欧美男生操女生| 中文字幕一区免费在线观看| 不卡的av电影| 成人免费在线视频| 欧美色老头old∨ideo| 日韩国产一区二| 色婷婷精品大在线视频| 亚洲精品ww久久久久久p站| 欧美日韩一二三区| 日本欧美在线观看| 日韩久久精品一区| 国产成人在线观看免费网站| 亚洲精品一区二区精华| 国产精品888| 樱桃视频在线观看一区| 日韩一区二区三区精品视频| 国产精品一区在线| 亚洲欧美视频在线观看视频| 7777女厕盗摄久久久| 狠狠色丁香婷综合久久| 中文字幕av一区 二区| 在线欧美一区二区| 久热成人在线视频| 亚洲欧洲色图综合| 欧美日本在线播放| 国产精品77777| 亚洲图片有声小说| 国产清纯在线一区二区www| 欧美区视频在线观看| 国产高清亚洲一区| 亚洲综合一二区| 日韩欧美国产麻豆| 在线欧美日韩国产| 国产成人av电影在线观看| 亚洲综合无码一区二区| 欧美激情一区在线观看| 在线播放/欧美激情| 成人黄色大片在线观看| 日本色综合中文字幕| 亚洲精品国产成人久久av盗摄| 国产亚洲综合色| 日韩欧美精品在线视频| 在线欧美日韩国产| 国产不卡在线一区| 美女高潮久久久| 午夜欧美在线一二页| 依依成人综合视频| 最新热久久免费视频|