实现像php一样方便的go ORM数据库操作示例详解

作者:程序员汤汤 时间:2024-05-05 09:27:25 

引言

很多人都是从php转过来的吧,不知道你们有没有发现,go界的orm并没有像php的orm一样好用。这篇文章里,我们认真的讨论下这个问题,并且会在后面提出解决方案。

php的方便

比如你想实现一个关联查询,在php里,你只需要不断的使用箭头函数就可以了。

$users = DB::table('users')->whereIn('id', [1, 2, 3])->orderBy('name', 'desc')->get();

以上代码,很简单实现了对一个表的查询操作,并且将查询结果以name做倒序排列,很简单

但是做同样的工作,在go里面就比较麻烦了

go的麻烦

如果你使用go的原生查询的话,你需要写如下的代码

rows, err := db.Query("select * from users where id in (?,?,?) order by name desc", 1, 2, 3)

基本上说,你需要手写一个完整的sql语句,全手动

什么!手写sql语句,不是咱不会写,关键是没必要手写啊,是吧。

全手写可能带来两个问题

  • 某些同学对于sql语法可能不熟悉,容易有语法错误

  • 某些同学可能写sql不认真,容易有拼写错误,尤其是条件多,占位符多的时候

如果你使用gorm之类的orm工具,可能会这样写

db.Where("id in (?)", []int{1,2,3}).Order("create_time desc").Find(&users)

很显然对比原生的来说,好一些,不用手写select 等关键字了,但是核心问题还是没解决,还需要手写 id in (?) 之类的。相当于之前是全手工,现在是半手工半自动了。

我这个例子里,条件就一个,在实际业务中,查询条件会有很多,并且数量还不一定,这种半自动的方法还是不太好的。

解决方案

既然有问题,那就有解决方案。很明显,最理想的方案就是保持与php的一致。那么go能做到这样吗?

答案是毫无疑问的,可以的。

这里推荐一个新的数据库操作库,可以很方便的完成这样的工作

tangpanqing/aorm: Operate Database So Easy For GoLang Developer (github.com)

它有一些显著的特性

  •  代码简洁,高性能

  •  支持 MySQL,MsSQL,Postgres,Sqlite3 数据库

  •  支持 空值查询

  •  支持 自动迁移

  •  支持 SQL 拼接

我们来看具体使用,就刚才的操作

aorm.Use(db).Table("users").WhereIn("id", []int{1,2,3}).OrderBy("name","desc").GetMany(&users)

对比php的写法

$users = DB::table('users')->whereIn('id', [1, 2, 3])->orderBy('name', 'desc')->get();

不能说一模一样吧,那简直是一模一样是不是?

我们再来看看如果是查询条件不确定怎么办?

这是列表查询经常遇到的问题,前端传过来的数据数量是不一定的,我们需要根据不同的数据,来增加或者减少不同的条件,进而产生不同的sql,查询不同的结果

var listByWhere []Person
   var where1 []builder.WhereItem
   where1 = append(where1, builder.WhereItem{Field: "type", Opt: builder.Eq, Val: 0})
   where1 = append(where1, builder.WhereItem{Field: "age", Opt: builder.In, Val: []int{18, 20}})
   where1 = append(where1, builder.WhereItem{Field: "money", Opt: builder.Between, Val: []float64{100.1, 200.9}})
   where1 = append(where1, builder.WhereItem{Field: "money", Opt: builder.Eq, Val: 100.15})
   where1 = append(where1, builder.WhereItem{Field: "name", Opt: builder.Like, Val: []string{"%", "li", "%"}})
   aorm.Use(db).Debug(true).Table("person").WhereArr(where1).GetMany(&listByWhere)
   for i := 0; i < len(listByWhere); i++ {
       fmt.Println(listByWhere[i])
   }

如上,你可以定义一个builder.WhereItem的切片(数组),然后根据前端传过来的信息,来增加和减少这个数组里的项,最后将这个查询数组,传递给aorm进行最后查询,最终得到结果。

由上面的例子可以看出,和PHP一样,你只是需要输入关键的字段名,关键的数据这就行了,其他的sql关键字,以及多种条件的拼接,aorm库自动帮你完成了。完美解决语法错误问题,以及拼写错误问题。

怎么样,香不香?

写在最后

aorm库非常的好用,为go工程师带来了php一般的开发体验,推荐各位快快用起来。

tangpanqing/aorm: Operate Database So Easy For GoLang Developer (github.com)

来源:https://juejin.cn/post/7181654898805571643

标签:go,ORM,数据库,操作
0
投稿

猜你喜欢

  • python添加列表元素append(),extend()及 insert()

    2021-03-07 06:17:50
  • python中rc1什么意思

    2023-10-24 13:01:38
  • Django+Uwsgi+Nginx如何实现生产环境部署

    2023-02-08 00:48:48
  • Python版中国省市经纬度

    2021-05-10 20:25:12
  • python 内置函数filter

    2023-01-07 21:53:37
  • Python数据处理的三个实用技巧分享

    2023-07-01 23:37:13
  • python函数enumerate,operator和Counter使用技巧实例小结

    2022-08-09 07:02:32
  • Python入门之模块和包用法详解

    2021-08-28 10:58:14
  • 一文带你熟悉Go语言中函数的使用

    2023-07-13 08:22:23
  • python实现图片批量压缩程序

    2021-11-27 03:50:11
  • 解决PyCharm同目录下导入模块会报错的问题

    2023-06-12 22:39:55
  • Python爬虫实战之网易云音乐加密解析附源码

    2022-08-28 04:03:58
  • JS出现失效的情况总结

    2023-08-24 00:44:42
  • CSS中expression的用法

    2008-09-11 14:18:00
  • 原生javascript实现DIV拖拽并计算重复面积

    2024-04-29 13:18:17
  • php删除路径下的所有文件夹和文件的代码

    2023-05-27 18:44:35
  • 使用Python matplotlib绘制简单的柱形图、折线图和直线图

    2022-04-08 02:13:19
  • 影响SQL Server性能的三个关键点

    2009-03-09 13:11:00
  • Python中的Socket 与 ScoketServer 通信及遇到问题解决方法

    2021-02-01 04:08:12
  • MYSQL SERVER收缩日志文件实现方法

    2024-01-26 15:14:29
  • asp之家 网络编程 m.aspxhome.com