從資料庫中讀取數據 在 "http://sqlitebrowser.org/" 下載sqlite3可視化工具,在本main.go同目錄下創建 資料庫,創建表如下: 將數據插入資料庫 ...
從資料庫中讀取數據
在http://sqlitebrowser.org/下載sqlite3可視化工具,在本main.go同目錄下創建personal.db
資料庫,創建表如下:
package main
import (
"database/sql"
"fmt"
_ "github.com/mattn/go-sqlite3"
)
// 用struct類型將來自SQL資料庫的數據映射到記憶體中的對象
type Profile struct {
ProfileId int
FirstName string
LastName string
Age int
}
func main() {
db, err := sql.Open("sqlite3", "./personal.db")
checkError(err)
var profile Profile
// Query可以使用參數
rows, err := db.Query("select ProfileId, FirstName, LastName, Age from Profile where FirstName = ? and LastName = ?", "Tarik", "Guney")
checkError(err)
for rows.Next() {
err := rows.Scan(&profile.ProfileId, &profile.FirstName, &profile.LastName, &profile.Age)
checkError(err)
fmt.Println(profile)
}
rows.Close()
db.Close()
}
func checkError(err error) {
if err != nil {
panic(err)
}
}
將數據插入資料庫
package main
import (
_ "github.com/mattn/go-sqlite3"
"database/sql"
"fmt"
)
type Profile struct{
ProfileId int
FirstName string
LastName string
Age int
}
func main(){
db, err := sql.Open("sqlite3", "./personal.db")
checkError(err)
/* 更新資料庫數據
statement, err := db.Prepare("update Profile set FirstName = ? where ProfileId = ?")
checkError(err)
statement.Exec("Martha", 5)
*/
statement, err := db.Prepare("insert into Profile (FirstName, LastName, Age) values(?,?,?)")
checkError(err)
statement.Exec("Jessica", "McArthur", 30)
/* 刪除資料庫數據
statement ,err := db.Prepare("delete from Profile where ProfileId = ?")
checkError(err)
statement.Exec(3)
*/
var profile Profile
rows, err := db.Query("select ProfileId, FirstName, LastName, Age from Profile")
checkError(err)
for rows.Next(){
err := rows.Scan(&profile.ProfileId, &profile.FirstName, &profile.LastName, &profile.Age)
checkError(err)
fmt.Println(profile)
}
rows.Close()
db.Close()
}
func checkError(err error) {
if (err != nil) {
panic(err)
}
}