- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
第
Go框架三件套Gorm?Kitex?Hertz基本用法与常见API讲解
目录三件套介绍GormKitexHertz三件套使用Gorm声明模型模型定义约定gorm.Model连接到数据库MySQL使用现有数据库连接CRUD接口批量插入通过Map数据类型创建记录查询检索单个对象检索对象条件查询选择特定字段Order查询LimitOffset查询GroupHaving查询Distinct查询高级查询智能选择字段子查询From子查询Group条件更新保存所有字段更新单个列更新多列更新选定字段批量更新获取更新的记录数删除删除一条记录根据主键删除批量删除返回删除行的数据软删除事务禁用默认事务事务开启嵌套事务手动事务Gorm性能提高Kitex安装使用编写IDL生成echo服务代码编写echo服务逻辑编译运行编写客户端发起调用Hertz安装命令行工具hz确定代码放置位置编写示例代码运行示例代码Hertz路由优先级Hertz中间件服务端中间件实现一个中间件Server级别中间件路由组级别中间件使用默认中间件客户端中间件实现一个中间件注册一个中间件总结
三件套介绍
Gorm、Kitex、Hertz的基本用法与常见的API讲解
Gorm
gorm是Golang语言中一个已经迭代数十年且功能强大、性能极好的ORM框架
ORM:ObjectRelationalMapping(对象关系映射),其主要作用是在编程中,把面向对象的概念跟数据库中表的概念对应起来,
简单来说,在golang中,自定义的一个结构体对应着一张表,结构体的实例则对应着表中的一条记录。
Kitex
Kitex是字节内部Golang微服务RPC框架具有高性能、强可扩展的主要特点支持多协议并且拥有丰富的开源扩展
Hertz
Hertz是字节内部的Http框架参考了其他开源框架的优势结合字节跳动内部的需求具有高可用、高性能、高扩展性的特点
三件套使用
该部分笔记主要参考:gorm.io/zh_CN/docs
声明模型
模型定义
模型是标准的struct,由Go的基本数据类型、实现了Scanner和Valuer接口的自定义类型及其指针或别名组成
typeUserstruct{
IDuint
Namestring
Email*string
Ageuint8
Birthday*time.Time
MemberNumbersql.NullString
ActivatedAtsql.NullTime
CreatedAttime.Time
UpdatedAttime.Time
约定
GORM倾向于约定优于配置
默认情况下,GORM使用ID作为主键,使用结构体名的蛇形复数作为表名,字段名的蛇形作为列名,并使用CreatedAt、UpdatedAt字段追踪创建、更新时间
gorm.Model
GORM定义一个gorm.Model结构体,其包括字段ID、CreatedAt、UpdatedAt、DeletedAt
//gorm.Model的定义
typeModelstruct{
IDuint`gorm:primaryKey`
CreatedAttime.Time
UpdatedAttime.Time
DeletedAtgorm.DeletedAt`gorm:index`
还可以将它嵌入到结构体中,以包含这几个字段,例如:
typeUserstruct{
gorm.Model
Namestring
//等效于
typeUserstruct{
IDuint`gorm:primaryKey`
CreatedAttime.Time
UpdatedAttime.Time
DeletedAtgorm.DeletedAt`gorm:index`
Namestring
连接到数据库
GORM官方支持的数据库类型有:MySQL,PostgreSQL,SQlite,SQLServer
MySQL
import(
gorm.io/driver/mysql
gorm.io/gorm
funcmain(){
//参考/go-sql-driver/mysql#dsn-data-source-name获取详情
dsn:=user:pa
您可能关注的文档
最近下载
- 油田开发与分析研究知识问答汇编.doc VIP
- 2025陕西公需课党的二十届三中全会精神解读与高质量发展答案.docx VIP
- NFPA 110-2019 国外国际标准.pdf VIP
- 宿舍规章制度十条.docx VIP
- (2025)第九届全国中小学“学宪法、讲宪法”活动知识竞赛题库及答案.pdf VIP
- 严明党的纪律和规矩论述摘编.docx VIP
- 福建省福州第一中学2024-2025学年高一下学期第四学段模块考试(7月期末)数学试题(含部分答案).pdf
- DB36∕T 1601-2022 猪场粪污异位发酵处理技术规程.pdf VIP
- 甘肃白银有色集团股份有限公司招聘真题.docx VIP
- 《科研基金申请撰写策略》课件.ppt VIP
文档评论(0)