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

标签 sql go

在 php 中,我可以打印 rowcount,其中 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 解决方案。 source link

通过上面的 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....
/*
rows1, err := db.Query("SELECT COUNT(*) as postCount FROM like_unlike 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)

}
*/


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)
}

关于sql - 如何避免使用 for next 方法获取行数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55091671/

相关文章:

go - 如何将值重新分配为 map 输出的空值

go - 使用Echo时编译错误

go - runtime.LockOSThread() 和 runtime.UnlockOSThread 问题

php - Mysql根据一张表的ID从2张表中选择数据

sql - 在事务中使用@@IDENTITY 是否安全?

python - 使用 MySQLdb 向表中插入行时出错

api - ItunesConnectApi JWT

go - 利用静态文件的浏览器缓存

MySQL:选择仅包含列表中的元素及其组合的条目

php - 当我使用内连接关键字时得到错误的数据