Facebook 开源 Golang 实体框架 Ent 现已支持 TiDB
对于后端开发者来说,一款好用的框架能够大大提升应用的开发效率。为了降低开发者使用 TiDB 的门槛,方便开发者快速连接到 TiDB,我们也在和合作伙伴一起,逐步完善面向主流开发语言和框架的连接支持。
近日,Facebook 开源的 Golang 实体框架 Ent 完成了对 TiDB 数据库的支持。 Ent 是一款易于构建和维护应用程序与大数据模型的框架。具有以下特点:
- Schema 即代码:能将任何数据库表建模为 Go 对象;
- 轻松地遍历任何图形 :可以轻松地运行查询、聚合和遍历任何图形结构;
- 静态类型和显式 API:使用代码生成静态类型和显式 API,查询数据更加便捷;
- 多存储驱动程序:支持 MySQL、PostgreSQL、SQLite、Gremlin,现在也已经支持了 TiDB;
- 可扩展:易于扩展和使用 Go 模板自定义。
下面通过一个 Hello World 的应用示例,来看下如何快速实现一个基于 Ent + TiDB 的应用。
Hello World 应用示例
1.用 Docker 在本地启动一个 TiDB Server
docker run -p 4000:4000 pingcap/tidb
现在你应该有一个运行的 TiDB 实例,开放了 4000 端口监听。
2.在本地拷贝 hello world 的示例 repo
git clone https://github.com/hedwigz/tidb-hello-world.git
在这个示例 repo 中我们定义了一个简单的 User schema
go title="ent/schema/user.go" func (User) Fields() []ent.Field { return []ent.Field{ field.Time("created_at"). Default(time.Now), field.String("name"), field.Int("age"), } }
然后,连接 Ent 和 TiDB:
go title="main.go" client, err := ent.Open("mysql", "root@tcp(localhost:4000)/test?parseTime=true") if err != nil { log.Fatalf("failed opening connection to TiDB: %v", err) } defer client.Close() // Run the auto migration tool, with Atlas. if err := client.Schema.Create(context.Background(), schema.WithAtlas(true)); err != nil { log.Fatalf("failed printing schema changes: %v", err) }
可以看到,在第一行我们通过一个 MySQL 语句去连接 TiDB Server,因为 TiDB 是兼容 MySQL 的,所以不需要其他特殊的 driver。 话虽如此,TiDB 和 MySQL 还是有很多不同,尤其是与 Schema 迁移相关的操作,比如 SQL 诊断和迁移规划。所以,Atlas 可以自动监测出是连接到 TiDB,做相应的迁移处理。 此外,第七行我们使用schema.WithAtlas(true)
,表示 Ent 是使用“Atlas”作为迁移引擎。Atlas 是 Ent 刚刚发布的迁移引擎,得益于 Atlas 的最新设计,对新数据库的支持也变得前所未有的简单。
最后,我们新建一条 user 数据,并保存到 TiDB 中,以用于后需的数据读取和输出。
go title="main.go" client.User.Create(). SetAge(30). SetName("hedwigz"). SaveX(context.Background()) user := client.User.Query().FirstX(context.Background()) fmt.Printf("the user: %s is %d years old\n", user.Name, user.Age)
3.运行这个示例程序:
$ go run main.go the user: hedwigz is 30 years old
在这次快速演练中,我们成功实现了:
- 启动一个本地的 TiDB 实例;
- 连接 Ent 和 TiDB 数据库;
- 使用 Atlas 迁移 Ent Schema;
- 使用 Ent 从 TiDB 中插入和读取数据。
版本说明
目前,这个示例应用在 Ent v0.10 和 TiDB v5.4.0 中可以正常运行,Ent 也计划在未来继续拓展对 TiDB 的支持。如果你使用其他版本的 TiDB 或者需要帮助,欢迎加入 asktug.com 来交流。如果你也有项目希望与 TiDB 适配,欢迎来 GitHub 提交 issue 。 除了 Ent,TiDB 此前已经添加了对 GORM 和 go-sql-driver/mysql 的支持,详情可查看文档: https://docs.pingcap.com/appdev/dev

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
从建好到用好,阿里云原生微服务生态的演进
作者:微服务小组 本文整理自阿里云智能高级技术专家彦林的线上直播分享《阿里云原生微服务生态与规划》。视频回放地址:https://yqh.aliyun.com/live/detail/28187 随着微服务技术的成熟,微服务核心架构分层愈加清晰,技术标准化和产业化正在形成,服务治理成为用好、管好服务的必选项,服务网格则成为多语言微服务架构下的技术趋势,阿里云原生微服务生态的演进恰好映射了微服务行业的发展和变化。 微服务行业趋势 从行业报告和微服务开源产品关注度上看微服务领域保持 20%+的高速增长,随着数字化加速,加深,系统复杂度上升,越来越多系统适合采用微服务,随着开源和云计算推进,微服务采用成本从百万级下降到万级,随着人力成本不断提升,微服务更利于提升研发&迭代效率,提高人效;总体整个行业进入成熟阶段,并且逐渐渗透到各行各业。 • 2018-2023,全球微服务市场 CAGR 22.4%,2023 年预计达到$1.8 Billion,亚太区市场规模市场份额 35%,仅次于北美地区。(数据来源:Marketsandmakets)。 • 阿里微服务领域开源产品的关注度提升 20...
- 下一篇
一首古诗带来的图数据库大冒险
本文首发于 Nebula Graph Community 公众号 因为图数据库的增长趋势一直位列前茅,每年都有媒体预测今年是“图年”。作为曾经的图数据库从业者,Nebula Hackthon 2021 的参赛队伍临江仙的队长王二铁(王建奎),一直在思考,为什么长期火爆的图数据库市场,一直没有真正引爆。在 2018 年图数据库输给了区块链,2019 年又遇到了 5G,随后疫情开始了。在王二铁看来图数据库目前主要还是面向 toB、toG 的市场,在 toC 领域,几乎没有图数据库相关的案例,这也是为什么图技术难以被大众所熟知的原因。 于是,一个新意的 idea 冒出了,这将是一个非常好,而且还算好玩的 C 端案例。它是什么呢?便是本次介绍的「一首古诗带来的图数据库大冒险」。 念起 有次二铁陪同小朋友上画画班,空闲之余刷到了苏轼的《临江仙 风水洞作》: 四大从来都遍满,此间风水何疑。故应为我发新诗。幽花香涧谷,寒藻舞沦漪。 借与玉川生两腋,天仙未必相思。还凭流水送人归。层巅余落日,草露已沾衣。 因为读不懂这首诗词,体会不到其中的意境美。作为老二次元的王二铁借由动漫迷中的「圣地巡礼」,想到用诗...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- SpringBoot2整合MyBatis,连接MySql数据库做增删改查操作
- CentOS7编译安装Gcc9.2.0,解决mysql等软件编译问题
- Red5直播服务器,属于Java语言的直播服务器
- CentOS7编译安装Cmake3.16.3,解决mysql等软件编译问题
- CentOS8,CentOS7,CentOS6编译安装Redis5.0.7
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果
- 2048小游戏-低调大师作品
- CentOS6,7,8上安装Nginx,支持https2.0的开启
- Docker安装Oracle12C,快速搭建Oracle学习环境
- CentOS8编译安装MySQL8.0.19