Goravel ORM 新增模型关联,用 Golang 写关联也可以跟 Laravel 简单

hwbrzzl · · 1910 次点击 · 开始浏览    置顶
这是一个创建于 的主题,其中的信息可能已经有所发展或是发生改变。

## 关于 Goravel [Goravel](https://github.com/goravel/goravel) 是一个功能完备、具有良好扩展能力的 Web 应用程序框架。作为一个起始脚手架帮助 Golang 开发者快速构建自己的应用。框架风格与 Laravel 保持一致,让 PHPer 不用学习新的框架,也可以愉快的玩转 Golang! ORM 模块上新「模型关联」,好用的飞起,有码有真相! ### 定义模型 一个用户可以发布多篇文章 ```go type User struct { orm.Model Name string Posts []*Post } type Post struct { orm.Model UserID uint Name string } ``` ### 查找(同时预加载关联模型) ```go var user models.User facades.Orm.Query().With("Post").Find(&user) // 预加载多个关联模型(嵌套预加载) facades.Orm.Query().With("Post").With("Phone.Contact").Find(&user) // 为预加载添加约束 facades.Orm.Query().With("Post", "name = ?", "author").Find(&user) facades.Orm.Query().With("Post", func(query orm.Query) orm.Query { return query.Where("name = ?", "author") }).Find(&book) ``` ### 延迟预加载 ```go var user models.User facades.Orm.Query().Find(&user) facades.Orm.Query().Load(&user, "Post") // 为预加载添加约束 facades.Orm.Query().Load(&book, "Post", "name = ?", "author").Find(&book) facades.Orm.Query().Load(&book, "Post", func(query orm.Query) orm.Query { return query.Where("name = ?", "author") }).Find(&book) ``` ### 创建(同时创建关联模型) ```go user := User{Name: "user", Post: &Post{Name: "post"}} // 创建 User 的同时创建所有子关联 facades.Orm.Query().Select(orm.Associations).Create(&user) ``` 更多使用细节请 [查看文档](https://github.com/goravel/goravel),Welcome Star, PR and Issues!

有疑问加站长微信联系(非本文作者)

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

1910 次点击  
加入收藏 微博
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传