在 Go 语言中,可以使用 database/sql
包来处理 SQL 查询。为了提高代码的可读性和可维护性,可以使用以下优雅的写法:
sqlx
库:sqlx
是一个基于 database/sql
的库,它提供了一些额外的功能,例如命名参数、数据库类型检查等。可以使用以下命令安装:go get -u github.com/jmoiron/sqlx
import (
_ "github.com/go-sql-driver/mysql"
"github.com/jmoiron/sqlx"
)
func main() {
db, err := sqlx.Connect("mysql", "user:password@tcp(localhost:3306)/dbname")
if err != nil {
log.Fatalln(err)
}
defer db.Close()
}
type User struct {
ID int64 `db:"id"`
Name string `db:"name"`
Email string `db:"email"`
CreatedAt time.Time `db:"created_at"`
}
var user User
err := db.Get(&user, "SELECT * FROM users WHERE id = ?", 1)
if err != nil {
log.Fatalln(err)
}
var users []User
err := db.Select(&users, "SELECT * FROM users")
if err != nil {
log.Fatalln(err)
}
_, err := db.Exec("INSERT INTO users (name, email) VALUES (?, ?)", "John Doe", "john@example.com")
if err != nil {
log.Fatalln(err)
}
_, err := db.Exec("UPDATE users SET name = ?, email = ? WHERE id = ?", "Jane Doe", "jane@example.com", 1)
if err != nil {
log.Fatalln(err)
}
_, err := db.Exec("DELETE FROM users WHERE id = ?", 1)
if err != nil {
log.Fatalln(err)
}
这些示例展示了如何使用 sqlx
库编写优雅的 Go 语言 SQL 代码。
领取专属 10元无门槛券
手把手带您无忧上云