Facebook 開源 Golang 實(shí)體框架 Ent 現(xiàn)已支持 TiDB

  對(duì)于后端開發(fā)者來說,一款好用的框架能夠大大提升應(yīng)用的開發(fā)效率。為了降低開發(fā)者使用 TiDB 的門檻,方便開發(fā)者快速連接到 TiDB,PingCAP也在和合作伙伴一起,逐步完善面向主流開發(fā)語言和框架的連接支持。近日,F(xiàn)acebook 開源的 Golang 實(shí)體框架 Ent 完成了對(duì) TiDB 數(shù)據(jù)庫(kù)的支持。

  Ent 是一款易于構(gòu)建和維護(hù)應(yīng)用程序與大數(shù)據(jù)模型的框架。具有以下特點(diǎn):

  Schema 即代碼:能將任何數(shù)據(jù)庫(kù)表建模為 Go 對(duì)象;

  輕松地遍歷任何圖形 :可以輕松地運(yùn)行查詢、聚合和遍歷任何圖形結(jié)構(gòu);

  靜態(tài)類型和顯式 API:使用代碼生成靜態(tài)類型和顯式 API,查詢數(shù)據(jù)更加便捷;

  多存儲(chǔ)驅(qū)動(dòng)程序:支持 MySQL、PostgreSQL、SQLite、Gremlin,現(xiàn)在也已經(jīng)支持了 TiDB;

  可擴(kuò)展:易于擴(kuò)展和使用 Go 模板自定義。

  下面通過一個(gè) Hello World 的應(yīng)用示例,來看下如何快速實(shí)現(xiàn)一個(gè)基于 Ent + TiDB 的應(yīng)用。

  Hello World 應(yīng)用示例

  用 Docker 在本地啟動(dòng)一個(gè) TiDB Server

  現(xiàn)在應(yīng)該有一個(gè)運(yùn)行的 TiDB 實(shí)例,開放了 4000 端口監(jiān)聽。

  在本地拷貝 hello world 的示例 repo

  在這個(gè)示例 repo 中定義了一個(gè)簡(jiǎn)單的 User schema

  然后,連接 Ent 和 TiDB:

  可以看到,在第一行通過一個(gè) MySQL 語句去連接 TiDB Server,因?yàn)?TiDB 是兼容 MySQL 的,所以不需要其他特殊的 driver。

  話雖如此,TiDB 和 MySQL 還是有很多不同,尤其是與 Schema 遷移相關(guān)的操作,比如 SQL 診斷和遷移規(guī)劃。所以,Atlas 可以自動(dòng)監(jiān)測(cè)出是連接到 TiDB,做相應(yīng)的遷移處理。

  此外,第七行使用 schema.WithAtlas(true),表示 Ent 是使用“Atlas”作為遷移引擎。Atlas 是 Ent 剛剛發(fā)布的遷移引擎,得益于 Atlas 的最新設(shè)計(jì),對(duì)新數(shù)據(jù)庫(kù)的支持也變得前所未有的簡(jiǎn)單。

  最后,新建一條 user 數(shù)據(jù),并保存到 TiDB 中,以用于后需的數(shù)據(jù)讀取和輸出。

  運(yùn)行這個(gè)示例程序:

  在這次快速演練中,成功實(shí)現(xiàn)了:

  啟動(dòng)一個(gè)本地的 TiDB 實(shí)例;

  連接 Ent 和 TiDB 數(shù)據(jù)庫(kù);

  使用 Atlas 遷移 Ent Schema;

  使用 Ent 從 TiDB 中插入和讀取數(shù)據(jù);

  版本說明

  目前,這個(gè)示例應(yīng)用在 Ent v0.10 和 TiDB v5.4.0 中可以正常運(yùn)行,Ent 也計(jì)劃在未來繼續(xù)拓展對(duì) TiDB 的支持。如果用戶使用其他版本的 TiDB 或者需要幫助,歡迎加入 asktug.com 來交流。如果也有項(xiàng)目希望與 TiDB 適配,歡迎來 GitHub 提交 issue。

  除了 Ent,TiDB 此前已經(jīng)添加了對(duì) GORM 和 go-sql-driver/mysql 的支持,詳情可查看文檔:https://docs.pingcap.com/appdev/dev

(免責(zé)聲明:本網(wǎng)站內(nèi)容主要來自原創(chuàng)、合作伙伴供稿和第三方自媒體作者投稿,凡在本網(wǎng)站出現(xiàn)的信息,均僅供參考。本網(wǎng)站將盡力確保所提供信息的準(zhǔn)確性及可靠性,但不保證有關(guān)資料的準(zhǔn)確性及可靠性,讀者在使用前請(qǐng)進(jìn)一步核實(shí),并對(duì)任何自主決定的行為負(fù)責(zé)。本網(wǎng)站對(duì)有關(guān)資料所引致的錯(cuò)誤、不確或遺漏,概不負(fù)任何法律責(zé)任。
任何單位或個(gè)人認(rèn)為本網(wǎng)站中的網(wǎng)頁或鏈接內(nèi)容可能涉嫌侵犯其知識(shí)產(chǎn)權(quán)或存在不實(shí)內(nèi)容時(shí),應(yīng)及時(shí)向本網(wǎng)站提出書面權(quán)利通知或不實(shí)情況說明,并提供身份證明、權(quán)屬證明及詳細(xì)侵權(quán)或不實(shí)情況證明。本網(wǎng)站在收到上述法律文件后,將會(huì)依法盡快聯(lián)系相關(guān)文章源頭核實(shí),溝通刪除相關(guān)內(nèi)容或斷開相關(guān)鏈接。 )