MySQL 是一款流行的關系型數據庫管理系統,它具有高效、可靠和易于使用等優點,被廣泛應用于各種互聯網應用、數據管理和分析等場景。
在 MySQL 中,比賽及其組合是一種經典的應用場景。比賽組合通常是指在一個比賽中,有多個組合參與競爭,每個組合有不同的成績得分和排名,需要對這些數據進行管理和統計。
CREATE TABLE `competition` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(50) NOT NULL COMMENT '比賽名稱', `start_time` datetime NOT NULL COMMENT '開始時間', `end_time` datetime NOT NULL COMMENT '結束時間', PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='比賽表'; CREATE TABLE `combo` ( `id` int(11) NOT NULL AUTO_INCREMENT, `comp_id` int(11) NOT NULL COMMENT '比賽 ID', `name` varchar(50) NOT NULL COMMENT '組合名稱', `score` decimal(5,2) NOT NULL COMMENT '得分', `rank` int(11) NOT NULL COMMENT '排名', PRIMARY KEY (`id`), KEY `comp_id` (`comp_id`), CONSTRAINT `combo_ibfk_1` FOREIGN KEY (`comp_id`) REFERENCES `competition` (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='組合表';
上面的代碼是創建比賽和組合表的示例 SQL 語句。其中 `competition` 表存儲比賽的基本信息,包括比賽名稱、開始時間和結束時間等;`combo` 表存儲各個組合的得分和排名等信息,并通過外鍵關聯到 `competition` 表。
通過這兩個表,我們可以很方便地管理和統計比賽中的組合數據,比如查詢某個比賽的所有組合得分排名、更新某個組合的得分和排名等操作。