中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

設計MySQL數據庫常常會遇到的問題

發布時間:2020-05-25 11:25:57 來源:PHP中文網 閱讀:455 作者:三月 欄目:MySQL數據庫

本文主要給大家介紹設計MySQL數據庫常常會遇到的問題,文章內容都是筆者用心摘選和編輯的,具有一定的針對性,對大家的參考意義還是比較大的,下面跟筆者一起了解下設計MySQL數據庫常常會遇到的問題吧。

第一題:層級數據庫設計

題目描述:現在有10萬條左右的數據,記錄一個部門的員工。大部門下是層級結構,有許多個子部門。比如,一級部分A,二級部門A’,B’,C’,三級部門A”,B”,C”。試問如何設計數據庫,我們需要統計二級部分A’下的所有人數。
分析:
這里用到了一個層級數據庫的設計。

CREATE TABLE DEPARTMENT(
    DEP_ID INT UNSIGNED AUTO_INCREMENT,
    DEP_NAME VARCHAR(10) NOT NULL,
    PARENT_ID INT,    
    PRIMARY KEY(DEP_ID)
)CHARSET=utf8;

設計MySQL數據庫常常會遇到的問題
插入數據

單個插入
INSERT INTO DEPARTMENT (DEP_NAME, PARENT_ID)
VALUES
('A',NULL);
或者批量插入
INSERT INTO department VALUES(1,'A',NULL),(2,'B',1),(3,'C',1),
        (4,'D',2),(5,'E',2),(6,'F',3),(7,'G',3);
dep_iddep_nameparent_id
1ANULL
2B1
3C1
4D2
5E2
6F3
7G3

設計MySQL數據庫常常會遇到的問題
顯示層級,這里用到了left join,根據這一級的dep_id,尋找它的parent_id,然后通過左連接進行連接,得到當前部門以及他的父部門。

select d1.dep_name as level1, d2.dep_name as level2, d3.dep_name as level3, d4.dep_name as level4
from department as d1
left join department as d2 on d2.parent_id = d1.dep_id 
left join department as d3 on d3.parent_id = d2.dep_id
left join department as d4 on d4.parent_id = d3.dep_id
where d1.dep_name='A';

設計MySQL數據庫常常會遇到的問題
當存儲好了部門的層級信息后,我們就開始設計一個部門人員的表。
創建表,并存儲部門人員的信息

create table people(
    id INT UNSIGNED AUTO_INCREMENT,
    name varchar(10) not null,
    dep_id INT UNSIGNED,
    departname varchar(10),   
    FOREIGN KEY (dep_id) REFERENCES department(dep_id),    
    primary key(id)
    )charset=utf8;

設計MySQL數據庫常常會遇到的問題
插入相關的測試數據。

INSERT INTO people VALUES(1,'hgy',4,'D'),(2,'abc',5,'E'),(3,'def',6,'F'),
        (4,'ddd',2,'B'),(5,'eee',2,'B');

設計MySQL數據庫常常會遇到的問題
查找二級部門為B的人,并且列出了他的上級部門信息

select p.id, p.name, d1.dep_name as level1, d2.dep_name as level2, d3.dep_name as level3
from people as p
left join department as d1 on d1.dep_id = p.dep_id
left join department as d2 on d2.dep_id  = d1.parent_id
left join department as d3 on d3.dep_id = d2.parent_id
where d1.dep_name='B' or d2.dep_name='B' or d3.dep_name='B';

設計MySQL數據庫常常會遇到的問題
查找二級部門為B的總人數

select count(*) as total
from people as p
left join department as d1 on d1.dep_id = p.dep_id
left join department as d2 on d2.dep_id  = d1.parent_id
left join department as d3 on d3.dep_id = d2.parent_id
where d1.dep_name='B' or d2.dep_name='B' or d3.dep_name='B';
idnamedepartment_iddepartname
1hgy4D
2abc5E
3def6F
4ddd2B
5eee2B

應該考慮到有的人在二級部門(可能沒有三級部門,沒有四級部門),有的人在一級部門,有的人在四級部門(有一級部門,二級部門,三級部門,四級部門)。
設計MySQL數據庫常常會遇到的問題

第二題:簡單的統計

題目描述:現在有一批學生的成績,求四門學科總分大于200的學生,并且按逆序排列。

CREATE TABLE STUDENT(
    ID INT UNSIGNED AUTO_INCREMENT,
    SCORE1 INT NOT NULL,
    SCORE2 INT NOT NULL,
    SCORE3 INT NOT NULL,
    SCORE4 INT NOT NULL,    
    PRIMARY KEY(ID)
)CHARSET=utf8;

設計MySQL數據庫常常會遇到的問題

INSERT INTO STUDENT VALUES(1,100,98,10,4),(2,100,9,10,4),(3,70,0,180,40),(4,10,98,1,4),(5,30,7,10,4),(6,8,88,1,43);

設計MySQL數據庫常常會遇到的問題
根據四門成績的總分進行排序

SELECT id, score1,score2,score3,score4, score1+score2+score3+score4 as total 
FROM STUDENTwhere score1+score2+score3+score4 > 200 order by score1+score2+score3+score4 desc;

設計MySQL數據庫常常會遇到的問題
這里是一個不能直接用別名來排序的知識點,

看完以上關于設計MySQL數據庫常常會遇到的問題,很多讀者朋友肯定多少有一定的了解,如需獲取更多的行業知識信息 ,可以持續關注我們的行業資訊欄目的。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

武宣县| 丰台区| 德昌县| 栖霞市| 平阴县| 龙江县| 浙江省| 浮山县| 河间市| 德昌县| 乌兰察布市| 墨江| 广汉市| 政和县| 四子王旗| 宣武区| 嵊泗县| 容城县| 武平县| 武冈市| 阿拉尔市| 铜鼓县| 萨迦县| 福安市| 开封市| 宁乡县| 陆川县| 禄丰县| 福海县| 简阳市| 皮山县| 白朗县| 卓尼县| 美姑县| 琼海市| 芒康县| 尉氏县| 木里| 三门峡市| 肥乡县| 瓮安县|