登录
首页 >  Golang >  Go问答

在MongoDB Go中查找字段的最大值方法

来源:stackoverflow

时间:2024-02-27 13:39:26 456浏览 收藏

你在学习Golang相关的知识吗?本文《在MongoDB Go中查找字段的最大值方法》,主要介绍的内容就涉及到,如果你想提升自己的开发能力,就不要错过这篇文章,大家要知道编程理论基础和实战操作都是不可或缺的哦!

问题内容

这是我的代码。即使有更多块(例如 3000 个块),我总是得到最大值 999。

这就是文档的样子。

func GetLatestBlockFromMongoDB() int{
    if contains(ReturnBlocksExists(), "blocks") == true {
        ctx, cancel := context.WithTimeout(context.Background(), 10*time.Second)
        var blockheights []models.Block
        defer cancel()
    
        options := options.Find().SetProjection(bson.M{"block.header.blockNumber": 1})

        options.SetSort(bson.D{{"block.header.blockNumber", -1}})

        options.SetLimit(1)
    
        results, err := blocksCollections.Find(context.TODO(), bson.D{}, options)
    
        if err != nil {
            fmt.Println(err)
        }
    
        //reading from the db in an optimal way
        defer results.Close(ctx)
        for results.Next(ctx) {
            var singleBlock models.Block
            if err = results.Decode(&singleBlock); err != nil {
                fmt.Println(err)
            }
    
            blockheights = append(blockheights, singleBlock)
        }
        fmt.Println("%v", blockheights[0].Block.Header.BlockNumber)
        if len(strings.TrimSpace(blockheights[0].Block.Header.BlockNumber)) > 0{
            i, err := strconv.Atoi(blockheights[0].Block.Header.BlockNumber)
            if err != nil {
                glog.Fatalf("%v", err)
            }
            return i
        } else {
            return 0
        }
    } else {
        return 0
    }
}

如何获得blocknumber的最大值?我认为问题可能是因为 blocknumber 是字符串而不是整数。我不知道。我确实设置了排序并限制了 1,所以它应该可以正常工作。


正确答案


是的,你是对的,从图像中,我可以看到 blocknumber 字段是一个字符串,所以你不是在比较整数,而是在比较字符串,其中“999”大于“3000”:

例如:

package main

import (
    "fmt"
)

func findmax(a []string) string {
    m := a[0]
    for _, value := range a {
        if value > m {
            m = value
        }
    }
    return m
}

func main() {
    blocks := []string{"999", "2000", "3000"}
    ma := findmax(blocks)
    fmt.println(ma)
}
$ go run .
999

也请查看 this question

今天关于《在MongoDB Go中查找字段的最大值方法》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>