[go-linq]-Go的.NET LINQ式查询方法
关于我
开发者的福音,go也支持linq了
坑爹的集合
go在进行集合操作时,有很不舒服的地方,起初我真的是无力吐槽,又苦于找不到一个好的第三方库,只能每次写着重复代码。举个栗子
类 学生{
姓名
年龄
性别
}
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。
没有依赖!
使用迭代器模式完成延迟求值
对并发使用是安全的
支持泛型函数,使您的代码更干净,并且没有类型断言
支持数组、片、映射、字符串、通道和自定义集合
使用
go get gopkg.in/ahmetb/go-linq.v3
import . "gopkg.in/ahmetb/go-linq.v3"
import . 的意思是直接使用库的方法,而不使用前缀。当然你也可以添加,官方的写法是这样的。
案例
定义一个员工类
type Employee struct {
Name string
Age int
Sex int // 0 男 1 女
WorkYear int //工龄
}
创建不同的列表
func initEmployeeData() []Employee {
list := make([]Employee, 0)
for i := 0; i < 10; i++ {
list = append(list, Employee{
Name: "张" + strconv.Itoa(i%4),
Age: 10 + i,
Sex: i % 2,
WorkYear: 1 + i%3,
})
}
return list
}
func initSameEployeeData() []Employee {
list := make([]Employee, 0)
for i := 0; i < 10; i++ {
list = append(list, Employee{
Name: "张一",
Age: 10,
Sex: i % 2,
WorkYear: 1,
})
}
return list
}
小试牛刀-distinct去除开始
func distinct() {
var manEmpRows []Employee
rows := initSameEployeeData()
fmt.Println("===性别是男的所有员工列表去重===")
From(rows).Distinct().ToSlice(&manEmpRows)
fmt.Println(manEmpRows)
}
=性别是男的所有员工列表去重=
[{张一 10 0 1} {张一 10 1 1}]
结果非常nice,本来我们需要的繁琐步骤,一个linq就解决了,是不是戝Diao!
众里寻他千百度-where过滤
//where 过滤条件
var manEmpRows []Employee
fmt.Println("===过滤性别是男的员工===")
From(rows).WhereT(func(e Employee) bool {
return e.Sex == 0
}).ToSlice(&manEmpRows)
fmt.Println(manEmpRows)
荣获三甲-take+sort
//Take 选取从头开始的几个元素
fmt.Println("===过滤性别是男的员工,只选择前俩个===")
From(rows).WhereT(func(e Employee) bool {
return e.Sex == 0
}).Take(2).ToSlice(&manEmpRows)
fmt.Println(manEmpRows)
排序。单字段排序,多字段组合排序。
//where过滤+排序
fmt.Println("===过滤性别是女的员工,且按照工龄降序排序===")
From(rows).WhereT(func(e Employee) bool {
return e.Sex == 1
}).OrderByDescendingT(func(e Employee) int {
return e.WorkYear
}).ToSlice(&manEmpRows)
fmt.Printf("%+v\n", manEmpRows)
//where 过滤+双重排序
fmt.Println("===过滤性别是女的员工,且按照工龄降序排序,再按照年龄升序排序===")
From(rows).WhereT(func(e Employee) bool {
return e.Sex == 1
}).OrderByDescendingT(func(e Employee) int {
return e.WorkYear
}).ThenByT(func(e Employee) int {
return e.Age
}).ToSlice(&manEmpRows)
弱水三千 只取一瓢-Select
//只获取元素中的某些字段,list输出
var outputRows []string
fmt.Println("===只获取元素中的某些字段,list输出===")
From(rows).SelectT(func(e Employee) string {
return e.Name
}).ToSlice(&outputRows)
fmt.Println(outputRows)
蜂合蚁聚-聚合
//聚合函数
query := From(rows).SelectT(func(e Employee) int {
return e.Age
})
fmt.Println(query.Average())
fmt.Println(query.Max())
fmt.Println(query.Min())
fmt.Println(query.Count())[]
其他
//获取结构体数组首个元素或者末个
firstItem := From(rows).First()
fmt.Println(firstItem)
lastItem := From(rows).Last()
fmt.Println(lastItem)
总结
通过介绍,不知道大家对go-linq有没有了一个简单的认识,对Linq的使用有一个大概的了解。如果有,那就参照编码自己手撸一遍,加强印象。
其他的特性大家自行查看官方说明,还有更多有趣的Linq语法糖等着你探索。
参考资料
最后
推荐阅读
End
本文到此结束,希望对你有帮助
更多精彩技术文章汇总在我的公众号 程序员工具集 ,持续更新,欢迎关注订阅收藏。
如果还有什么疑问或者建议,可以多多交流,原创文章,文笔有限,才疏学浅,文中若有不正之处,万望告知。
[go-linq]-Go的.NET LINQ式查询方法的更多相关文章
- Spring Data Jpa (四)注解式查询方法
详细讲解声明式的查询方法 1 @Query详解 使用命名查询为实体声明查询是一种有效的方法,对于少量查询很有效.一般只需要关心@Query里面的value和nativeQuery的值.使用声明式JPQ ...
- Linq专题之创建Linq查询表达式
本节我们主要介绍一下如何创建查询集合类型,关系数据库类型,DataSet对象类型和XML类型的数据源的Linq查询表达式. 下面在实例代码ReadyCollectionData()函数创建了准备的数据 ...
- Linq学习之旅——LINQ查询表达式
1. 概述 2. from子句 3. where子句 4. select子句 5. group子句 6. into子句 7. 排序子句 8. let子句 9. join子句 10. 小结 1. 概述 ...
- LINQ之路 8: 解释查询(Interpreted Queries)
LINQ提供了两个平行的架构:针对本地对象集合的本地查询(local queries),以及针对远程数据源的解释查询(Interpreted queries). 在讨论LINQ to SQL等具体技术 ...
- LINQ之路 7:子查询、创建策略和数据转换
在前面的系列中,我们已经讨论了LINQ简单查询的大部分特性,了解了LINQ的支持计术和语法形式.至此,我们应该可以创建出大部分相对简单的LINQ查询.在本篇中,除了对前面的知识做个简单的总结,还会介绍 ...
- LINQ - 在Where條件式中使用in與not in
希望对大家在以后的项目中能用到,我也是在项目中碰到了这个问题: 算算時間,接觸LINQ也有一個月的時間了,可以算是落伍兼新生,不過最近在寫專案的時候,遇到了在LINQ的Where條件式中要如何使用in ...
- 让LINQ中的查询语法使用自定义的查询方法
使用LINQ时有两种查询语法:查询语法和方法语法 查询语法:一种类似 SQL 语法的查询方式 方法语法:通过扩展方法和Lambda表达式来创建查询 例如: List<, , , }; //查询语 ...
- 几种查询方法(lambda Linq Enumerable静态类方式)
1.需要一个数据源类: using System; using System.Collections.Generic; namespace Linq { public class Student { ...
- LINQ入门教程之各种标准查询操作符(一)
好久之前就想系统的学习下LINQ,好久之前…… 本篇文章主要介绍LINQ等的标准查询操作符,内容取自<LINQ高级编程>,后续还会介绍LINQ to XML ,LINQ to SQL. L ...
随机推荐
- vue & this.$copyText
vue & this.$copyText click copy https://www.npmjs.com/package/vue-clipboard2 <p>{{message2 ...
- ossutilmac64
ossutilmac64 ossutil是以命令行方式管理OSS数据的工具,提供方便.简洁.丰富的存储空间(Bucket)和文件(Object)管理命令,支持Windows.Linux. Mac平台. ...
- SwiftUI & MVVM
SwiftUI & MVVM design paradigm / 设计模式 MVVM Model View ViewModel MVVM Architecture 架构 MVC Model V ...
- Java REPL & JShell
Java REPL & JShell Java 11 JShell Java Shell https://www.infoq.com/articles/jshell-java-repl/ Th ...
- 2019 front-end job Interview
2019 front-end job Interview 2019 前端面试题 掘金 https://juejin.im/tag/面试 https://juejin.im/post/5c875791e ...
- c++ 使用PID获取可执行文件路径
注意看备注 https://docs.microsoft.com/en-us/windows/win32/api/psapi/nf-psapi-getmodulefilenameexa #includ ...
- VS Code使用Git可视化管理源代码详细教程
前言: 随着VS Code的功能和插件的不断强大和完善,它已经成为了我们日常开发中一个必不可缺的伙伴了.在之前我曾经写过一篇SourceTree使用教程详解(一个git可视化管理神器,想要了解的话可以 ...
- springCloud服务流程
springCloud的服务流程:消费者调用生产者 1.通过接口化的请求调用(指定接口的服务名字和服务地址)只是做定义,并没有真正做到. 2.Feign组件,远程去注册中心找到服务的名字和服务的地址然 ...
- Vue学习笔记-VSCode安装与配置
一 使用环境: windows 7 64位操作系统 二 VSCode安装与配置 1.下载: https://code.visualstudio.com 直接点击即可. 2. 点击按装程序,默认安 ...
- Java基本概念:方法
一.简介 描述: Java中方法是语句的集合,它们在一起执行一个功能. 方法是解决一类问题的步骤的有序组合,它在类中定义,属于类的成员,包含于类或对象中. 方法在程序中被创建后,在其他使用了该方法的地 ...