首页 > 数据库 >万万没想到,go也能使用对象来操作数据库了,网友直呼:健壮性有保证了

万万没想到,go也能使用对象来操作数据库了,网友直呼:健壮性有保证了

时间:2023-01-13 16:33:57浏览次数:69  
标签:直呼 健壮性 数据库 Aorm person 操作 go article

Hi,各位go的小伙伴,大家新年好。

之前给大家介绍的Aorm库,都用上了吗?这可是迄今为止我见过的,go领域最好用的数据库操作库了。

去年的时候(实际上是半个月前),我发了一篇文章来介绍Aorm的链式操作,展示了它的易用性。

《万万没想到,go的数据库操作,也能像php一样溜了》

不少朋友加我,表示了支持,并且提出了殷切希望。其中有一点,希望可以增加使用对象来操作数据库。

经过我半个月的研究与努力,现在它来了,它来了,它踏着魔鬼步伐走来了。

微信图片_20221226163624.png

什么是使用对象操作数据库

有很多朋友可能没听过说过这个事情,我就先拿别的语言的代码例子来简单介绍下

$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

核心优点:

  1. 支持 使用结构体(对象) 操作数据库,让你的系统更健壮

  2. 支持 MySQL,MsSQL,Postgres,Sqlite3 数据库,让你的系统更容易扩展

  3. 支持 链式操作,让你的开发效率更高

  4. 支持 空值查询或更新,让你的开发体验更好

  5. 支持 迁移数据结构,让你的数据迁移更方便

目前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的项目页面,有我个人微信,可以加我。

微信图片_20221226163643.png

标签:直呼,健壮性,数据库,Aorm,person,操作,go,article
From: https://www.cnblogs.com/tangpanqing/p/17049865.html

相关文章

  • python django 医院挂号系统
    pythondjango医院挂号系统pythondjango挂号管理系统pythondjango医院挂号管理系统后端:pythondjango数据库:MySQL5.7前端:html cssjs等涉及功能:登陆、退出......
  • python django个人云盘系统
    pythondjango云盘系统pythondjango个人云盘pythondjango本地云盘Pythondjango文件系统 后端:pythondjango数据库:MySQL5.7前端:html cssjs等涉及功能:登陆......
  • 【数据结构与算法】排序算法(Go实现)
    基础排序算法插入排序funcInsertSort(nums[]int){fori:=1;i<len(nums);i++{val:=nums[i]j:=iforj>0&&nums[j-1]>......
  • (9)go-micro微服务Redis配置
    目录一go-redis介绍二go-redis安装三redis初始化连接四存储mail邮件五存储token六最后一go-redis介绍Redis(RemoteDictionaryServer),即远程字典服务,是一个开......
  • go 语言 for循环的一个坑
    1、案例1packagemainimport"fmt"typeCardstruct{ idint}funcmain(){ list:=make([]*Card,0) card:=&Card{} forindex:=1;index<10;index......
  • 【Mongodb结合springboot 01】
    一、简介1、什么是MongoDBc++语言编写的,是一个基于分布式文件存储的开源数据库系统;为web应用提供可扩展的高性能数据存储解决方案;MongoDB将数据存储为一个文档,数据结构......
  • 【学习日志】MongoDB为什么选择B树,而MySQL选择B+树实现索引
    先说B树和B+树的区别B树:非叶子节点也存储数据B+树:只有叶子节点存储数据,且所有叶子节点通过指针相连接。为什么MongoDB选择B树而,MySQL选择B+树呢?两种数据结构的区别摆在......
  • MongoDB 数据类型
    MongoDB数据类型MongoDB将json格式的字符串转化为bson格式的数据进行存储,目的是节省存储空间,但同时不会改变json的样式。BSONisabinaryserializationformat......
  • 常用go开发包
    前言随着时间的推移,语言爱好者已经构建和共享了许多Go框架和库。这些包执行不同的功能,从开发微服务到制作discord机器人,一直到构建Web应用程序!在本文中,我将尝试让您......
  • 解决docker中mongo报Restarting (132) 5 seconds ago
    报的一直自动重启原因是自建服务器的机器不支持avx指令可以通过cat/proc/cpuinfo|grepavxorsudocat/proc/cpuinfo|grepavx查看你的系统是否支持avx指令,如......