Go是一種非常強大的編程語言,可以輕松地與各種數據庫進行交互。其中,MySQL是一種非常常用的關系型數據庫,本文將介紹如何使用Go與MySQL進行連接和操作。
首先,需要使用Go的官方MySQL驅動程序,可以通過以下命令進行安裝:
go get github.com/go-sql-driver/mysql
然后,可以使用以下代碼連接MySQL:
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 {
panic(err.Error())
}
defer db.Close()
err = db.Ping()
if err != nil {
panic(err.Error())
}
fmt.Println("Connected to MySQL database successfully!")
}
在以上代碼中,需要將“username”、“password”、“hostname”、“port”和“database”替換為實際的值。如果一切正常,將會看到“Connected to MySQL database successfully!”的消息。
可以使用以下代碼執行SQL查詢:
rows, err := db.Query("SELECT * FROM users WHERE status=?", 1)
if err != nil {
panic(err.Error())
}
defer rows.Close()
for rows.Next() {
var id int
var name string
var email string
var status int
err = rows.Scan(&id, &name, &email, &status)
if err != nil {
panic(err.Error())
}
fmt.Printf("id: %d, name: %s, email: %s, status: %d\n", id, name, email, status)
}
以上代碼將會查詢“users”表中所有狀態為“1”的用戶,并輸出結果到控制臺。
如果需要執行SQL插入、更新或刪除操作,可以使用以下代碼:
result, err := db.Exec("INSERT INTO users(name,email,status) VALUES (?,?,?)", "Tom", "[email protected]", 1)
if err != nil {
panic(err.Error())
}
id, err := result.LastInsertId()
if err != nil {
panic(err.Error())
}
fmt.Printf("Last inserted ID: %d\n", id)
以上代碼將會向“users”表中插入一條新記錄,并輸出插入記錄的ID。
總的來說,使用Go與MySQL進行交互非常簡單。只需要使用官方MySQL驅動程序,編寫相應的代碼即可實現連接和操作。通過這篇文章,相信讀者已經學會了如何使用Go與MySQL進行交互,期待讀者在實際應用中取得更進一步的成果。
上一篇mysql @%
下一篇go原生連接mysql