文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

如何避免使用 for next 方法来获取行数

2024-04-05 00:07

关注

小伙伴们有没有觉得学习Golang很有意思?有意思就对了!今天就给大家带来《如何避免使用 for next 方法来获取行数》,以下内容将会涉及到,若是在学习中对其中部分知识点有疑问,或许看了本文就能帮到你!

问题内容

在 php 中,我可以打印 postid 与下面的代码匹配的行计数,而无需在 while 循环中传递结果。

$status_query = "select count(*) as postcount from postdata where postid=1";
$status_result = mysqli_query($con,$status_query);
$status_row = mysqli_fetch_array($status_result);
$postcount = $status_row['postcount'];
echo $postcount;

现在正在将代码重写为 golang 以获得相同的行数。我利用这里找到的 stackoverflow 解决方案。 源码链接

通过上面的 stackoverflow 解决方案链接,下面的 golang 代码运行良好,因为我可以获得行数。

rows1, err := db.query("select count(*) as postcount from postdata where postid=1")
if err != nil {
    log.fatal(err)
}
defer rows1.close()
var  postcount int

for rows1.next() {   
    if err := rows1.scan(& postcount); err != nil {
        log.fatal(err)
    }
}

fmt.printf("number of rows are %s\n",  postcount)

这是我要修改的内容:

上面的代码传递了以内的行计数结果

for rows1. next(){
// result here.
}

我的问题是:

请如何避免这个 for rows.next() 函数并直接得到我的结果,因为我正在根据 postid 检索行数。 在上面的 php 代码中,我可以直接得到结果,而无需在 while 循环中传递它。

golang中,我正在考虑类似下面的代码

rows1, err := db.query("select count(*) as postcount from postdata where postid=1")
if err != nil {
    log.fatal(err)
}
defer rows1.close()
var status_row = rows1.next() 

var postcount =rows1.scan(& postcount)
fmt.printf("number of rows are %s\n",  postcount)

是否有人有更好的方法让此行计数直接显示,而无需在 rows1.next() 方法中传递结果

这是我在上面的编码插图中寻求修改之前的整体工作代码。

package main

import "database/sql"
import _ "github.com/go-sql-driver/mysql"

import "net/http"
import "fmt"
import "log"

var db *sql.DB
var err error


func getRecordPage1(res http.ResponseWriter, req *http.Request) {

    if req.Method != "POST" {
        http.ServeFile(res, req, "getjsonRecord.html")
        return
    }

//The commented section below is the code I want to modify to avoid use of for rows.next function....



func homePage(res http.ResponseWriter, req *http.Request) {
    http.ServeFile(res, req, "index.html")
}

func main() {
    db, err = sql.Open("mysql", "root:@/golang44")
    if err != nil {
        panic(err.Error())
    }
    defer db.Close()

    err = db.Ping()
    if err != nil {
        panic(err.Error())
    }

    http.HandleFunc("/getjsonRecord", getRecordPage1)
    http.HandleFunc("/", homePage)
        fmt.Println("Listening on 127.0.0.1:8088")
    http.ListenAndServe(":8088", nil)
}


解决方案


通常,如果您知道自己要获取一行,请使用 DB.QueryRow 它允许您将查询和扫描链接在一起,因此您的示例如下所示:

var  postCount int
err := db.QueryRow("SELECT COUNT(*) as postCount FROM postData WHERE postid=1").Scan(&postCount)
if err != nil {
    log.Fatal(err)
}

文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《如何避免使用 for next 方法来获取行数》文章吧,也可关注编程网公众号了解相关技术文章。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯