go语言查询mysql的返回结果判断处理

对于Query而言,没有数据是不会返回error,同时sql.rows也没有返回关于长度的属性,因此只能自己遍历rows属性,这是比较操蛋的事情,

对比而言QueryRow就相对于友好一点,如果没有返回结果,error的值会是sql.ErrNoRows,因此,判断这个值就能得到数据库中是否有我们需要的那个数据.

var name string
err := db.QueryRow(`select  name from user where uid=7`).Scan(&name)   //db为sql.DB
if err == sql.ErrNoRows {
   log.Print("没有结果")
} else {
   log.Print("youjieguo:",name)
}
  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
在 Go 语言中,你可以使用第三方的 MySQL 驱动程序来连接和操作数据库。下面是一个示例代码,展示了如何使用 Go 语言查询 MySQL 数据库,并返回某一个表中一个字段状态为1的关联字段数据总和的结果: ```go package main import ( "database/sql" "fmt" _ "github.com/go-sql-driver/mysql" ) func main() { db, err := sql.Open("mysql", "username:password@tcp(hostname:port)/database") if err != nil { fmt.Println("Failed to connect to MySQL:", err) return } defer db.Close() // 构建查询语句 query := "SELECT SUM(related_column_name) as total_sum FROM table_name WHERE status = 1" // 执行查询语句 rows, err := db.Query(query) if err != nil { fmt.Println("Failed to execute query:", err) return } defer rows.Close() // 读取结果 if rows.Next() { var totalSum int64 err = rows.Scan(&totalSum) if err != nil { fmt.Println("Failed to scan result:", err) return } fmt.Println("Total sum:", totalSum) } else { fmt.Println("No result found") } } ``` 请将 `username`、`password`、`hostname`、`port` 和 `database` 替换为你的 MySQL 连接信息,将 `related_column_name` 替换为要计算总和的关联字段名,将 `table_name` 替换为要查询的表名。然后使用该代码连接到你的 MySQL 数据库,执行查询语句,并将结果打印输出。 注意:该示例代码只提供了基本的查询功能,你可能需要根据实际情况进行错误处理、连接池管理等其他的操作。同时,确保你已经在你的 Go 项目中导入了 `database/sql` 和 MySQL 驱动的相关包,以及正确配置了数据库连接信息。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值