GoFrame ORM原生方法 开箱体验 (下)

简介: gf是支持ORM原生操作的,在ORM链式操作执行不了太过于复杂的SQL操作时,可以交给方法操作来处理。上一篇文章 整理了ORM的原生方法,这篇文章根据整理的原生方法整理对应的开箱体验。

开箱体验


1. ORM对象


// 获取默认配置的数据库对象(配置名称为"default")
db := g.DB()
// 获取配置分组名称为"user"的数据库对象
db := g.DB("user")
// 使用原生单例管理方法获取数据库对象单例
db, err := gdb.Instance()
db, err := gdb.Instance("user")


tips


不用的时候不需要使用Close方法关闭数据库连接,数据库引擎底层采用了链接池设计,当链接不再使用时会自动关闭


2. 数据写入


r, err := db.Insert(ctx, "user", gdb.Map {
    "name": "王中阳",
})


3. 数据查询(单条)


虽然limit 10,但是因为我们使用的是GetOne,仍然只会返回单条数据


one, err := db.GetOne(ctx, "select * from user limit 10")
one, err := db.GetOne(ctx, "select * from user where id=100")
one, err := db.GetOne(ctx, "select * from user where id=?", 100)
one, err := db.GetOne(ctx, "select * from user where id=?", g.Slice{100})


4. 数据查询(列表)


list, err := db.GetAll(ctx, "select * from user limit 10")
list, err := db.GetAll(ctx, "select * from user where age > ? and name like ?", g.Slice{20, "%金%"})
list, err := db.GetAll(ctx, "select * from user where status=?", g.Slice{1})


5. 数据保存


数据保存是Save,插入数据是insert,区别是是否指定主键


r, err := db.Save(ctx, "user", gdb.Map {
    "id"  :  1,
    "name" : "王中阳",
})


6. 批量操作


batch := 10
_, err := db.Insert(ctx, "user", gdb.List {
    {"name": "小明"},
    {"name": "小华"},
    {"name": "小军"},
    {"name": "小高"},
}, batch)


tips


  1. 其中batch参数用于指定批量操作中分批写入条数数量(默认是10)。
  2. 表示批量写入数据时的每批次数量,这个数值跟你数据库服务器配置的SQL BufferSize数值有关。


7. 数据更新/删除


// db.Update/db.Delete 同理
// UPDATE `user` SET `name`='王中阳' WHERE `id`=10000
r, err := db.Update(ctx, "user", gdb.Map {"name": "王中阳"}, "id=?", 10000)
// UPDATE `user` SET `name`='王中阳' WHERE `id`=10000
r, err := db.Update(ctx, "user", "name='王中阳'", "id=10000")
// UPDATE `user` SET `name`='王中阳' WHERE `id`=10000
r, err := db.Update(ctx, "user", "name=?", "id=?", "王中阳", 10000)


tips


参数建议使用?占位符进行输入,避免SQL注入风险。


总结


虽然GoFrame的ORM链式操作非常简单且强大,但是业务中总还是有一些逻辑需要使用原生方法实现,化繁为简。

相关实践学习
阿里云图数据库GDB入门与应用
图数据库(Graph Database,简称GDB)是一种支持Property Graph图模型、用于处理高度连接数据查询与存储的实时、可靠的在线数据库服务。它支持Apache TinkerPop Gremlin查询语言,可以帮您快速构建基于高度连接的数据集的应用程序。GDB非常适合社交网络、欺诈检测、推荐引擎、实时图谱、网络/IT运营这类高度互连数据集的场景。 GDB由阿里云自主研发,具备如下优势: 标准图查询语言:支持属性图,高度兼容Gremlin图查询语言。 高度优化的自研引擎:高度优化的自研图计算层和存储层,云盘多副本保障数据超高可靠,支持ACID事务。 服务高可用:支持高可用实例,节点故障迅速转移,保障业务连续性。 易运维:提供备份恢复、自动升级、监控告警、故障切换等丰富的运维功能,大幅降低运维成本。 产品主页:https://www.aliyun.com/product/gdb
相关文章
|
15天前
|
Java API 数据库
构建RESTful API已经成为现代Web开发的标准做法之一。Spring Boot框架因其简洁的配置、快速的启动特性及丰富的功能集而备受开发者青睐。
【10月更文挑战第11天】本文介绍如何使用Spring Boot构建在线图书管理系统的RESTful API。通过创建Spring Boot项目,定义`Book`实体类、`BookRepository`接口和`BookService`服务类,最后实现`BookController`控制器来处理HTTP请求,展示了从基础环境搭建到API测试的完整过程。
31 4
|
6月前
|
JavaScript Java 关系型数据库
学习平台|基于Springboot+vue的学习平台系统的设计与实现(源码+数据库+文档)
学习平台|基于Springboot+vue的学习平台系统的设计与实现(源码+数据库+文档)
84 0
|
3月前
|
SQL 关系型数据库 数据库连接
Entity Framework Core 入门教程来袭!快速上手强大的 ORM 工具,开启高效数据库开发之旅!
【8月更文挑战第31天】Entity Framework Core(EF Core)是一个轻量且可扩展的对象关系映射(ORM)框架,允许开发者使用 .NET 语言操作数据库而无需直接编写 SQL 语句。本教程涵盖 EF Core 的安装、数据库上下文创建、数据库连接配置及常见数据库操作(如添加、查询、更新和删除),并介绍如何利用数据库迁移功能安全地更改数据库结构。通过本教程,你可以快速掌握 EF Core 的基本用法,提高开发效率。
58 0
|
XML JavaScript 前端开发
SAP UI5 本地开发如何实现 XML 和 JavaScript 代码的自动完成和嵌入式 API 文档自动显示试读版
SAP UI5 本地开发如何实现 XML 和 JavaScript 代码的自动完成和嵌入式 API 文档自动显示试读版
|
6月前
|
移动开发 小程序 IDE
11月开发者日回顾|IDE支持版本管理、JSAPI新增预拉取能力、开发者高频问题详解
11月开发者日回顾|IDE支持版本管理、JSAPI新增预拉取能力、开发者高频问题详解
62 11
|
6月前
|
人工智能 供应链 监控
推荐一款TinyEngine低代码引擎!支持自定义DSL 生成定制的源码、跨技术栈!
推荐一款TinyEngine低代码引擎!支持自定义DSL 生成定制的源码、跨技术栈!
115 0
|
开发框架 JavaScript 小程序
扩展应用功能的无限可能——UniApp生态系统中的组件库与插件探索
扩展应用功能的无限可能——UniApp生态系统中的组件库与插件探索
|
6月前
|
JavaScript 前端开发 Java
深入探索Spring Boot的核心功能:快速构建原生程序响应式处理数据(文末送书)
深入探索Spring Boot的核心功能:快速构建原生程序响应式处理数据(文末送书)
61 0
|
6月前
|
Web App开发 存储 前端开发
谈谈企业级应用的自定义 UI 创建和集成方法一览
谈谈企业级应用的自定义 UI 创建和集成方法一览
|
移动开发 小程序 开发工具
Donut 多端框架是支持使用小程序原生语法开发移动应用的框架
Donut 多端框架是支持使用小程序原生语法开发移动应用的框架,开发者可以一次编码,分别编译为小程序和 Android 以及 iOS 应用,实现多端开发
422 0
Donut 多端框架是支持使用小程序原生语法开发移动应用的框架