经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 程序设计 » Go语言 » 查看文章
[go-linq]-Go的.NET LINQ式查询方法
来源:cnblogs  作者:三十三重天  时间:2021/3/29 9:12:03  对本文有异议

关于我

我的博客|文章首发

开发者的福音,go也支持linq了

坑爹的集合

go在进行集合操作时,有很不舒服的地方,起初我真的是无力吐槽,又苦于找不到一个好的第三方库,只能每次写着重复代码。举个栗子

  1. 学生{
  2. 姓名
  3. 年龄
  4. 性别
  5. }

1、现在有10个学生的数组,如果我要统计所有年龄大于20岁的人,那我需要

一、遍历

二、自定义条件

三、再append数组添加。

2、接着我又要统计性别为男的所有学生,我又要重复上面的步骤。

你说坑爹不坑爹,那是真的坑!

吐槽之处

重点是95%的代码都是一样的,只是那百分之几有点区别。对于一名合格的程序员,我是坚决不能忍受这种情况的发生。

解决方法

群里寻求大神帮助

混迹各大论坛,博客寻找有效信息

终于在老夫的不懈努力下,发现了一个库。它就是go-linq,使用它,能够解决我对集合大部分的需求,让编程更顺手,让工作更强经劲。

什么是Linq呢?

LINQ(发音:Link)是语言级集成查询(Language INtegrated Query)

?LINQ是一种用来进行数据访问的编程模型,使得.NET语言可以直接支持数据查询

Linq 是C#编程的一个爽的飞起的语法糖,使用过的人无一不对其高级的特性,偏自然语义化的折服。

那么问题来了

那么问题来了,go有没有类似的东西呢,答案是肯定的,这次是我们马上要说的库Go-linq。通过这名称你就知道他是做什么的了。不多说了,直接开Lu。

开始使用Go-Linq

Go-Linq介绍

一个强大的语言集成查询(LINQ)库的Go。

没有依赖!

使用迭代器模式完成延迟求值

对并发使用是安全的

支持泛型函数,使您的代码更干净,并且没有类型断言

支持数组、片、映射、字符串、通道和自定义集合

使用

  1. go get gopkg.in/ahmetb/go-linq.v3
  1. import . "gopkg.in/ahmetb/go-linq.v3"

import . 的意思是直接使用库的方法,而不使用前缀。当然你也可以添加,官方的写法是这样的。

案例

定义一个员工类

  1. type Employee struct {
  2. Name string
  3. Age int
  4. Sex int // 0 男 1 女
  5. WorkYear int //工龄
  6. }

创建不同的列表

  1. func initEmployeeData() []Employee {
  2. list := make([]Employee, 0)
  3. for i := 0; i < 10; i++ {
  4. list = append(list, Employee{
  5. Name: "张" + strconv.Itoa(i%4),
  6. Age: 10 + i,
  7. Sex: i % 2,
  8. WorkYear: 1 + i%3,
  9. })
  10. }
  11. return list
  12. }
  13. func initSameEployeeData() []Employee {
  14. list := make([]Employee, 0)
  15. for i := 0; i < 10; i++ {
  16. list = append(list, Employee{
  17. Name: "张一",
  18. Age: 10,
  19. Sex: i % 2,
  20. WorkYear: 1,
  21. })
  22. }
  23. return list
  24. }

小试牛刀-distinct去除开始

  1. func distinct() {
  2. var manEmpRows []Employee
  3. rows := initSameEployeeData()
  4. fmt.Println("===性别是男的所有员工列表去重===")
  5. From(rows).Distinct().ToSlice(&manEmpRows)
  6. fmt.Println(manEmpRows)
  7. }

=性别是男的所有员工列表去重=
[{张一 10 0 1} {张一 10 1 1}]

结果非常nice,本来我们需要的繁琐步骤,一个linq就解决了,是不是戝Diao!

众里寻他千百度-where过滤

  1. //where 过滤条件
  2. var manEmpRows []Employee
  3. fmt.Println("===过滤性别是男的员工===")
  4. From(rows).WhereT(func(e Employee) bool {
  5. return e.Sex == 0
  6. }).ToSlice(&manEmpRows)
  7. fmt.Println(manEmpRows)

荣获三甲-take+sort

  1. //Take 选取从头开始的几个元素
  2. fmt.Println("===过滤性别是男的员工,只选择前俩个===")
  3. From(rows).WhereT(func(e Employee) bool {
  4. return e.Sex == 0
  5. }).Take(2).ToSlice(&manEmpRows)
  6. fmt.Println(manEmpRows)

排序。单字段排序,多字段组合排序。

  1. //where过滤+排序
  2. fmt.Println("===过滤性别是女的员工,且按照工龄降序排序===")
  3. From(rows).WhereT(func(e Employee) bool {
  4. return e.Sex == 1
  5. }).OrderByDescendingT(func(e Employee) int {
  6. return e.WorkYear
  7. }).ToSlice(&manEmpRows)
  8. fmt.Printf("%+v\n", manEmpRows)
  9. //where 过滤+双重排序
  10. fmt.Println("===过滤性别是女的员工,且按照工龄降序排序,再按照年龄升序排序===")
  11. From(rows).WhereT(func(e Employee) bool {
  12. return e.Sex == 1
  13. }).OrderByDescendingT(func(e Employee) int {
  14. return e.WorkYear
  15. }).ThenByT(func(e Employee) int {
  16. return e.Age
  17. }).ToSlice(&manEmpRows)

弱水三千 只取一瓢-Select

  1. //只获取元素中的某些字段,list输出
  2. var outputRows []string
  3. fmt.Println("===只获取元素中的某些字段,list输出===")
  4. From(rows).SelectT(func(e Employee) string {
  5. return e.Name
  6. }).ToSlice(&outputRows)
  7. fmt.Println(outputRows)

蜂合蚁聚-聚合

  1. //聚合函数
  2. query := From(rows).SelectT(func(e Employee) int {
  3. return e.Age
  4. })
  5. fmt.Println(query.Average())
  6. fmt.Println(query.Max())
  7. fmt.Println(query.Min())
  8. fmt.Println(query.Count())[]

其他

  1. //获取结构体数组首个元素或者末个
  2. firstItem := From(rows).First()
  3. fmt.Println(firstItem)
  4. lastItem := From(rows).Last()
  5. fmt.Println(lastItem)

总结

通过介绍,不知道大家对go-linq有没有了一个简单的认识,对Linq的使用有一个大概的了解。如果有,那就参照编码自己手撸一遍,加强印象。

其他的特性大家自行查看官方说明,还有更多有趣的Linq语法糖等着你探索。

参考资料

github源码

官方使用说明

最后

推荐阅读

Redis工具收费后新的开源已出现

GitHub上Star最高的工程师技能图谱

中国程序员最容易发错的单词

推荐!!! Markdown图标索引网站)

End

本文到此结束,希望对你有帮助 ??

更多精彩技术文章汇总在我的公众号 程序员工具集 ,持续更新,欢迎关注订阅收藏。

如果还有什么疑问或者建议,可以多多交流,原创文章,文笔有限,才疏学浅,文中若有不正之处,万望告知。

原文链接:http://www.cnblogs.com/foxhappy/p/14589221.html

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号