日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁(yè) > 單片機(jī) > 架構(gòu)師社區(qū)
[導(dǎo)讀]來(lái)自:程序通事 忙,真忙 這兩個(gè)星期真是巨忙,年前有個(gè)項(xiàng)目因?yàn)楦鞣N莫名原因,一直拖到這個(gè)月才開(kāi)始真正測(cè)試。然后上周又接到新需求,馬不停蹄進(jìn)入開(kāi)發(fā)。 一邊開(kāi)發(fā)著新需求,一邊改著舊項(xiàng)目的 Bug。再加上這個(gè)項(xiàng)目算是從別人那交給過(guò)來(lái)的,這部分新功能代碼

一個(gè)實(shí)用技巧,告別手動(dòng)畫(huà)圖,自動(dòng)生成數(shù)據(jù)庫(kù) ER 圖|原創(chuàng)

來(lái)自:程序通事

忙,真忙

這兩個(gè)星期真是巨忙,年前有個(gè)項(xiàng)目因?yàn)楦鞣N莫名原因,一直拖到這個(gè)月才開(kāi)始真正測(cè)試。然后上周又接到新需求,馬不停蹄進(jìn)入開(kāi)發(fā)。

一邊開(kāi)發(fā)著新需求,一邊改著舊項(xiàng)目的 Bug。再加上這個(gè)項(xiàng)目算是從別人那交給過(guò)來(lái)的,這部分新功能代碼并不是很熟,改 Bug 的時(shí)候又需要理清楚上下文邏輯,非常耗時(shí)間。

這不有一天狀態(tài)還不好,迷迷糊糊中改了一天 Bug,又寫了一天 Bug。

一個(gè)實(shí)用技巧,告別手動(dòng)畫(huà)圖,自動(dòng)生成數(shù)據(jù)庫(kù) ER 圖|原創(chuàng)

自產(chǎn)自銷,問(wèn)題有點(diǎn)大,后面幾天一直填自己的挖的坑,那叫一個(gè)酸爽。

一個(gè)實(shí)用技巧,告別手動(dòng)畫(huà)圖,自動(dòng)生成數(shù)據(jù)庫(kù) ER 圖|原創(chuàng)

好了,不水了,不水了!

本周沒(méi)啥時(shí)間寫技術(shù)文,那就寫點(diǎn)輕松的,分享一個(gè)日常比較實(shí)用的功能『自動(dòng)生成數(shù)據(jù)庫(kù) ER 圖

自動(dòng)生成 ER 圖

平常做技術(shù)方案設(shè)計(jì)的時(shí)候,如果有涉及到表結(jié)構(gòu)的變更,就需要在文檔中說(shuō)明,還得將表結(jié)構(gòu)信息寫到文檔中,類似如下:

一個(gè)實(shí)用技巧,告別手動(dòng)畫(huà)圖,自動(dòng)生成數(shù)據(jù)庫(kù) ER 圖|原創(chuàng)

如果是一個(gè)新項(xiàng)目,新增了多張表,手動(dòng)將字段填到表格中,再畫(huà)個(gè) ER 圖,很是費(fèi)勁。

一個(gè)實(shí)用技巧,告別手動(dòng)畫(huà)圖,自動(dòng)生成數(shù)據(jù)庫(kù) ER 圖|原創(chuàng)

這不最近剛好發(fā)現(xiàn)了 IDEA Database 插件,可以自動(dòng)生成 ER 圖。

假設(shè)現(xiàn)有兩張表 activityvisitor,表結(jié)構(gòu)如下:

CREATE TABLE activity
(
    activity_id int          NOT NULL,
    title       varchar(256NOT NULL,
    PRIMARY KEY (activity_id)

);


CREATE TABLE visitor
(
    id          int NOT NULL,
    activity_id int NOT NULL,
    PRIMARY KEY (id),
    FOREIGN KEY (activity_id) REFERENCES activity(activity_id)
);

在 IDEA Database 彈框中選中相應(yīng)的表,右鍵菜單選擇 Diagrams-Show Visualisation,就可以生成 ER 圖。

一個(gè)實(shí)用技巧,告別手動(dòng)畫(huà)圖,自動(dòng)生成數(shù)據(jù)庫(kù) ER 圖|原創(chuàng)

ps: maven 包之間的層級(jí)關(guān)系也可以用這個(gè)功能展示

由于存在真實(shí)外鍵,IDEA Database 生成 ER 圖的時(shí)候?qū)?huì)自動(dòng)生成外鍵的關(guān)系。

 一個(gè)實(shí)用技巧,告別手動(dòng)畫(huà)圖,自動(dòng)生成數(shù)據(jù)庫(kù) ER 圖|原創(chuàng)

但是真實(shí)生產(chǎn)環(huán)境,我們很少會(huì)建立這種真實(shí)物理外鍵關(guān)系,僅僅只會(huì)在邏輯上生成一個(gè)虛擬的外鍵的關(guān)系。

具體原因可以參考阿里巴巴『Java 開(kāi)發(fā)手冊(cè)

一個(gè)實(shí)用技巧,告別手動(dòng)畫(huà)圖,自動(dòng)生成數(shù)據(jù)庫(kù) ER 圖|原創(chuàng)

這種情況下,如果 IDEA 的版本低于 2019.3.2,那就別想了,直接用下節(jié)提到的工具。

IDEA 2019.3.2 新增了虛擬外鍵的功能,在 ER 圖增加生成虛擬外鍵的功能。

假設(shè)現(xiàn)有表結(jié)構(gòu)如下:

CREATE TABLE activity
(
    activity_id int          NOT NULL,
    visitor_id      int NOT NULL,
    PRIMARY KEY (activity_id)

);


CREATE TABLE visitor
(
    id          int NOT NULL,
    first_name int NOT NULL,
    PRIMARY KEY (id)
);

系統(tǒng)生成 ER 圖中將會(huì)生成虛擬外鍵關(guān)系。

一個(gè)實(shí)用技巧,告別手動(dòng)畫(huà)圖,自動(dòng)生成數(shù)據(jù)庫(kù) ER 圖|原創(chuàng)

不過(guò)不要高興太早,IDEA 是根據(jù)一定規(guī)則生成虛擬外鍵關(guān)系的。

如果你的表中外鍵命名不符合規(guī)則,IDEA 是不會(huì)生成外鍵的。我們需要在 Setting | Editor | Code Completion 設(shè)置規(guī)則。

一個(gè)實(shí)用技巧,告別手動(dòng)畫(huà)圖,自動(dòng)生成數(shù)據(jù)庫(kù) ER 圖|原創(chuàng)

說(shuō)白了就是設(shè)置正則表達(dá)式,設(shè)置完成之后,可以點(diǎn)擊 一個(gè)實(shí)用技巧,告別手動(dòng)畫(huà)圖,自動(dòng)生成數(shù)據(jù)庫(kù) ER 圖|原創(chuàng)這個(gè)按鈕進(jìn)行調(diào)試。

一個(gè)實(shí)用技巧,告別手動(dòng)畫(huà)圖,自動(dòng)生成數(shù)據(jù)庫(kù) ER 圖|原創(chuàng)

上面功能比較適合表結(jié)構(gòu)比較規(guī)范的情況,但是真實(shí)場(chǎng)景可能比較復(fù)雜,外鍵命名也不是規(guī)范。為了生成這個(gè)外鍵關(guān)系,還要配置正則規(guī)則,學(xué)習(xí)成本過(guò)很大,也很難啊。

一個(gè)實(shí)用技巧,告別手動(dòng)畫(huà)圖,自動(dòng)生成數(shù)據(jù)庫(kù) ER 圖|原創(chuàng)

不過(guò)好在 IDEA 有另外一個(gè)功能,可以手動(dòng)指定表之間的外鍵關(guān)系。

首先我們需要打開(kāi)一個(gè) IDEA Database console 窗口,在里面輸入連表 sql,然后使用 Alt+Enter 快捷鍵選擇 Store table relation

一個(gè)實(shí)用技巧,告別手動(dòng)畫(huà)圖,自動(dòng)生成數(shù)據(jù)庫(kù) ER 圖|原創(chuàng)

這是 IDEA 會(huì)提醒你保存這個(gè)外鍵關(guān)系到 xml 文件中。

一個(gè)實(shí)用技巧,告別手動(dòng)畫(huà)圖,自動(dòng)生成數(shù)據(jù)庫(kù) ER 圖|原創(chuàng)

生成 XML 文件如下:

一個(gè)實(shí)用技巧,告別手動(dòng)畫(huà)圖,自動(dòng)生成數(shù)據(jù)庫(kù) ER 圖|原創(chuàng)

如果還需要生成外鍵關(guān)系,直接在這個(gè)配置文件中增加即可。

dbschema

IDEA Database 生成虛擬外鍵,這樣看起來(lái)還是比較繁瑣的,下面介紹一款軟件『dbschema』,可以圖形化生成虛擬外鍵。

下載地址:https://dbschema.com/

ps:收費(fèi)軟件,免費(fèi) 15 天

這款軟件專門簡(jiǎn)化數(shù)據(jù)庫(kù)設(shè)計(jì)和管理,功能很強(qiáng)大,這里僅僅介紹其虛擬外鍵這個(gè)小功能,其他功能感興趣同學(xué)可以自行研究一下。

首先我們新建一個(gè) Layout,導(dǎo)入指定表。

一個(gè)實(shí)用技巧,告別手動(dòng)畫(huà)圖,自動(dòng)生成數(shù)據(jù)庫(kù) ER 圖|原創(chuàng)

生成 ER 圖如下:

一個(gè)實(shí)用技巧,告別手動(dòng)畫(huà)圖,自動(dòng)生成數(shù)據(jù)庫(kù) ER 圖|原創(chuàng)

選擇相應(yīng)的表,右鍵菜單選擇 Add Foreign Key

一個(gè)實(shí)用技巧,告別手動(dòng)畫(huà)圖,自動(dòng)生成數(shù)據(jù)庫(kù) ER 圖|原創(chuàng)

在新建窗口選擇相應(yīng)的表以及字段。

一個(gè)實(shí)用技巧,告別手動(dòng)畫(huà)圖,自動(dòng)生成數(shù)據(jù)庫(kù) ER 圖|原創(chuàng)

這里需要注意,我們是要生成虛擬的外鍵關(guān)系,所以一定要勾選下 Virtual,不然會(huì)生成真實(shí)物理外鍵。

最后 ER 圖如下:

一個(gè)實(shí)用技巧,告別手動(dòng)畫(huà)圖,自動(dòng)生成數(shù)據(jù)庫(kù) ER 圖|原創(chuàng)

我們可以將這個(gè) ER 圖以及表結(jié)構(gòu)導(dǎo)出到 PDF 中。在 Layout  選擇 Export。

一個(gè)實(shí)用技巧,告別手動(dòng)畫(huà)圖,自動(dòng)生成數(shù)據(jù)庫(kù) ER 圖|原創(chuàng)
一個(gè)實(shí)用技巧,告別手動(dòng)畫(huà)圖,自動(dòng)生成數(shù)據(jù)庫(kù) ER 圖|原創(chuàng)

最后生成 PDF 如下圖所示:

一個(gè)實(shí)用技巧,告別手動(dòng)畫(huà)圖,自動(dòng)生成數(shù)據(jù)庫(kù) ER 圖|原創(chuàng)

Reference

  1. https://www.jetbrains.com/help/idea/foreign-keys.html
  2. https://blog.jetbrains.com/datagrip/2020/01/22/datagrip-2019-3-2-virtual-foreign-keys-and-more/

特別推薦一個(gè)分享架構(gòu)+算法的優(yōu)質(zhì)內(nèi)容,還沒(méi)關(guān)注的小伙伴,可以長(zhǎng)按關(guān)注一下:

一個(gè)實(shí)用技巧,告別手動(dòng)畫(huà)圖,自動(dòng)生成數(shù)據(jù)庫(kù) ER 圖|原創(chuàng)

長(zhǎng)按訂閱更多精彩▼

一個(gè)實(shí)用技巧,告別手動(dòng)畫(huà)圖,自動(dòng)生成數(shù)據(jù)庫(kù) ER 圖|原創(chuàng)

如有收獲,點(diǎn)個(gè)在看,誠(chéng)摯感謝


免責(zé)聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺(tái)僅提供信息存儲(chǔ)服務(wù)。文章僅代表作者個(gè)人觀點(diǎn),不代表本平臺(tái)立場(chǎng),如有問(wèn)題,請(qǐng)聯(lián)系我們,謝謝!

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

LED驅(qū)動(dòng)電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: 驅(qū)動(dòng)電源

在工業(yè)自動(dòng)化蓬勃發(fā)展的當(dāng)下,工業(yè)電機(jī)作為核心動(dòng)力設(shè)備,其驅(qū)動(dòng)電源的性能直接關(guān)系到整個(gè)系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動(dòng)勢(shì)抑制與過(guò)流保護(hù)是驅(qū)動(dòng)電源設(shè)計(jì)中至關(guān)重要的兩個(gè)環(huán)節(jié),集成化方案的設(shè)計(jì)成為提升電機(jī)驅(qū)動(dòng)性能的關(guān)鍵。

關(guān)鍵字: 工業(yè)電機(jī) 驅(qū)動(dòng)電源

LED 驅(qū)動(dòng)電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個(gè)照明設(shè)備的使用壽命。然而,在實(shí)際應(yīng)用中,LED 驅(qū)動(dòng)電源易損壞的問(wèn)題卻十分常見(jiàn),不僅增加了維護(hù)成本,還影響了用戶體驗(yàn)。要解決這一問(wèn)題,需從設(shè)計(jì)、生...

關(guān)鍵字: 驅(qū)動(dòng)電源 照明系統(tǒng) 散熱

根據(jù)LED驅(qū)動(dòng)電源的公式,電感內(nèi)電流波動(dòng)大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關(guān)鍵字: LED 設(shè)計(jì) 驅(qū)動(dòng)電源

電動(dòng)汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動(dòng)汽車的核心技術(shù)之一是電機(jī)驅(qū)動(dòng)控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機(jī)驅(qū)動(dòng)系統(tǒng)中的關(guān)鍵元件,其性能直接影響到電動(dòng)汽車的動(dòng)力性能和...

關(guān)鍵字: 電動(dòng)汽車 新能源 驅(qū)動(dòng)電源

在現(xiàn)代城市建設(shè)中,街道及停車場(chǎng)照明作為基礎(chǔ)設(shè)施的重要組成部分,其質(zhì)量和效率直接關(guān)系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進(jìn)步,高亮度白光發(fā)光二極管(LED)因其獨(dú)特的優(yōu)勢(shì)逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關(guān)鍵字: 發(fā)光二極管 驅(qū)動(dòng)電源 LED

LED通用照明設(shè)計(jì)工程師會(huì)遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關(guān)鍵字: LED 驅(qū)動(dòng)電源 功率因數(shù)校正

在LED照明技術(shù)日益普及的今天,LED驅(qū)動(dòng)電源的電磁干擾(EMI)問(wèn)題成為了一個(gè)不可忽視的挑戰(zhàn)。電磁干擾不僅會(huì)影響LED燈具的正常工作,還可能對(duì)周圍電子設(shè)備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來(lái)解決L...

關(guān)鍵字: LED照明技術(shù) 電磁干擾 驅(qū)動(dòng)電源

開(kāi)關(guān)電源具有效率高的特性,而且開(kāi)關(guān)電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機(jī)重量也有所下降,所以,現(xiàn)在的LED驅(qū)動(dòng)電源

關(guān)鍵字: LED 驅(qū)動(dòng)電源 開(kāi)關(guān)電源

LED驅(qū)動(dòng)電源是把電源供應(yīng)轉(zhuǎn)換為特定的電壓電流以驅(qū)動(dòng)LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動(dòng)電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: LED 隧道燈 驅(qū)動(dòng)電源
關(guān)閉