万万没想到,go也能使用对象来操作数据库了,网友直呼:健壮性有保证了
Hi,各位go的小伙伴,大家新年好。
之前给大家介绍的Aorm库,都用上了吗?这可是迄今为止我见过的,go领域最好用的数据库操作库了。
去年的时候(实际上是半个月前),我发了一篇文章来介绍Aorm的链式操作,展示了它的易用性。
《万万没想到,go的数据库操作,也能像php一样溜了》
不少朋友加我,表示了支持,并且提出了殷切希望。其中有一点,希望可以增加使用对象来操作数据库。
经过我半个月的研究与努力,现在它来了,它来了,它踏着魔鬼步伐走来了。
什么是使用对象操作数据库
有很多朋友可能没听过说过这个事情,我就先拿别的语言的代码例子来简单介绍下
$users = DB::table('users')->whereIn('id', [1, 2, 3])->orderBy('name', 'desc')->get();
如上,PHP的代码里,一个简单的数据库查询语句,php的朋友很眼熟吧。
这里的出现的users, id, name都是字符串,都需要手动编写进去,弊端很明显
1. 开发的时候,容易产生拼写错误。
2. 重构的时候,或者字段名以及表名有更改的时候,那可就苦逼了。因为他们分布在项目的各个地方,你需要极其小心的,正确的找出来他们,然后修改。漏掉一个那就是一颗定时炸弹。
我们再来看看 .NET 里,如何解决这个问题
dbContext
.Person
.GroupJoin(
dbContext.Products,
person => person.Id,
product => product.Id,
(person, products) => new { Person = person, Products = products }
)
.SelectMany(
combination => combination.Products.DefaultIfEmpty(),
(person, products) => new {
PersonId = person.Person.Id,
PersonName = person.Person.Name,
ProductsId = products.Id,
ProductsName = products.Product
}
)
.ToList();
以上你看到的代码,里面没有一个手写的字符串,全都是对象类型,或者对象的属性。
开发的时候,你需要提前定义好对象以及属性,这比着php的开发,确实会多一些工作。但是维护的时候,超级省心。
如果你有表,或者字段需要修改,直接修改就好,编辑器会自动提示你,哪些字段没有了,高亮并且显示出来,一个都不会错,不会少。如果你不修改,编译的时候根本不通过。由此,你程序的健壮性就有保证了。开发完,你也可以安心的睡大觉了。
Aorm是什么
Aorm是一个基于go语言的数据库操作库。
项目地址: https://github.com/tangpanqing/aorm
核心优点:
-
支持 使用结构体(对象) 操作数据库,让你的系统更健壮
-
支持 MySQL,MsSQL,Postgres,Sqlite3 数据库,让你的系统更容易扩展
-
支持 链式操作,让你的开发效率更高
-
支持 空值查询或更新,让你的开发体验更好
-
支持 迁移数据结构,让你的数据迁移更方便
目前github上星星还不多,但是作者比较用心,文档还是很全的。有兴趣的可以移步看看。
Aorm如何使用对象来操作数据库
下面是我从Aorm的文档里,找到的关联查询的例子
aorm.Db(db).
Table(&article).
LeftJoin(
&person,
[]builder.JoinCondition{
builder.GenJoinCondition(&person.Id, builder.RawEq, &article.PersonId),
},
).
SelectAll(&article).
SelectAs(&person.Name, &articleVO.PersonName).
WhereEq(&article.Type, 0).
WhereIn(&person.Age, []int{18, 20}).
GetMany(&list2)
它产生的sql语句如下
SELECT article.*,person.name as person_name
FROM article
LEFT JOIN person ON person.id=article.person_id
WHERE article.type = ?
AND article.age IN (?,?)
0 18 20
对比代码和sql,如果你sql基础还可以的话,应该能够看出来代码里各方法的作用,以及各参数代表什么
如你所见,代码里&article
对应sql里的article
表, &person.Id
对应sql里的 person.id
字段,以此类推
看明白原理之后,我们再来审视代码,没有一个字段名是硬编码,也没有一个表名是硬编码。如同上面 .net 的例子,所有的操作,都是对象操作,它会让你的代码更健壮,维护和重构更方便。
结束语
通过本文,我们简单介绍了在go语言下,使用对象(结构体)来操作数据库,并且举了一些例子。
关于Aorm更多的特点或者文档,你可以去看Aorm的文档地址
项目地址: https://github.com/tangpanqing/aorm
另外,极力邀请各位朋友使用Aorm,如果使用的过程中遇到问题,欢迎使用各种渠道联系我。github的项目页面,有我个人微信,可以加我。
原文地址:https://www.cnblogs.com/tangpanqing/p/17049865.html
- Go-List
- 分享张戈博客自用的php网址在线转换二维码的API源码
- zabbix agentd客户端插件Shell一键自动安装脚本
- SendCloud邮件队列状态和已使用额度的Python监控脚本
- linux/scp命令报“bash: scp: command not found lost connection”错误的解决办法
- bat/cmd批处理连接SqlServer数据库查询脚本
- 一起用 HTML5 Canvas 做一个简单又骚气的粒子引擎
- 解决mstsc无法连接问题:由于没有远程桌面授权服务器可以提供许可证…
- Apache/Nginx伪静态规则匹配http://出现的问题与解决
- 微信文件微起底
- Go语言TCP Socket编程--1
- Go语言TCP Socket编程--2
- 服务器 数据库设计技巧--1
- CVE-2015-0235:Linux glibc高危漏洞的检测及修复方法
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- (十)python3 只需3小时带你轻松入门——模块与包
- (十一)python3 只需3小时带你轻松入门——面向对象
- 一文读懂KEGG数据库
- (创建模式 上)设计模式——工厂、抽象工厂 C++/Python3实现
- 【新手宝典】一篇博文带萌新建站并了解建站体系流程和对萌新友好的便捷方式,这篇博文很有可能是你的启蒙文
- 一种不需要敲代码的Python 画图方法
- 【一】Windows API 零门槛编程指南——MessageBox 基本使用及基础讲解
- 【二】Windows API 零门槛编程指南——CreateWindow 窗口创建 “万字长篇专业术语全解”
- 「零门槛多语言 Python/C/C# 通用思想学习系列」第一篇:经典HelloWorld
- 直播系统定制,判断数据连接是否可用
- VS Code 编辑器入门指南上篇-核心概念与组件
- Python turtle库实现基本剖析
- python thinker canvas create_arc 使用详解
- Python3 实现单例设计模式
- Python3 实现建造者模式