中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Golang怎么操作sqlite3數據庫

發布時間:2023-04-17 11:18:40 來源:億速云 閱讀:140 作者:iii 欄目:開發技術

這篇文章主要介紹了Golang怎么操作sqlite3數據庫的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇Golang怎么操作sqlite3數據庫文章都會有所收獲,下面我們一起來看看吧。

sqlite概述

sqlite是嵌入式關系型數據庫引擎,官方描述為自包含的、無服務的、零配置并支持事務的關系型數據庫引擎。我們在產品開發過程中經常使用,可以快速進行產品驗證和部署,快速實現產品演示。

Go有sql包,它提供了sql(或類sql)數據庫的通用接口。sql包必須與數據庫驅動程序一起使用。

創建SQLITE數據庫

使用sqlite3命令行工具創建數據庫,查詢數據。

sudo apt install sqlite3

安裝好工具,創建數據庫:

sqlite3 test.db
SQLite version 3.37.2 2022-01-06 13:25:41
Enter ".help" for usage hints.
sqlite>

test.db是sqlite3命令的參數,即為數據庫名稱,也是磁盤上的文件名。如果文件存在就打開,不存在則創建:

sqlite> .tables
sqlite> .exit

$ ls
test.db

.tables名稱列出test.db數據庫中所有表,當前沒有表;.exit命令終止活動session命令行工具。ls命令顯示當前目錄下的文件,可以看到我們創建的test.db文件。

打印版本

下面示例打印sqlite3的版本,主要通過SELECT SQLITE_VERSION()語句返回版本號:

package main

import (
	"database/sql"
	"fmt"
	"log"

	_ "github.com/mattn/go-sqlite3"
)

func main() {

	db, err := sql.Open("sqlite3", ":memory:")

	if err != nil {
		log.Fatal(err)
	}

	defer db.Close()

	var version string
	err = db.QueryRow("SELECT SQLITE_VERSION()").Scan(&version)

	if err != nil {
		log.Fatal(err)
	}

	fmt.Println(version)
}

首先導入包,這里導入前綴為下劃線,則init函數被執行。然后注冊驅動;

db, err := sql.Open("sqlite3", ":memory:")

Open函數指定驅動名稱和數據源名稱,本示例連接內存數據庫。接著調用db.Close函數,確保關閉數據庫并阻止啟動新的查詢。

err = db.QueryRow("SELECT SQLITE_VERSION()").Scan(&version)

QueryRow執行查詢,至少返回一行。Scan函數從返回行拷貝列至version變量。

$ go run main.go
3.39.4

Exec執行DML語句

Exec函數執行沒有返回記錄的查詢語句,即DML語句:

package main

import (
	"database/sql"
	"fmt"
	"log"

	_ "github.com/mattn/go-sqlite3"
)

func main() {

	db, err := sql.Open("sqlite3", "test.db")

	if err != nil {
		log.Fatal(err)
	}

	defer db.Close()

	sts := `
DROP TABLE IF EXISTS cars;
CREATE TABLE cars(id INTEGER PRIMARY KEY, name TEXT, price INT);
INSERT INTO cars(name, price) VALUES('Audi',52642);
INSERT INTO cars(name, price) VALUES('Mercedes',57127);
INSERT INTO cars(name, price) VALUES('Skoda',9000);
INSERT INTO cars(name, price) VALUES('Volvo',29000);
INSERT INTO cars(name, price) VALUES('Bentley',350000);
INSERT INTO cars(name, price) VALUES('Citroen',21000);
INSERT INTO cars(name, price) VALUES('Hummer',41400);
INSERT INTO cars(name, price) VALUES('Volkswagen',21600);
`
	_, err = db.Exec(sts)

	if err != nil {
		log.Fatal(err)
	}

	fmt.Println("table cars created")
}

首先創建數據庫,生成新的數據庫文件:

db, err := sql.Open("sqlite3", "test.db")

接著創建表并插入數據。通過_, err = db.Exec(sts)語句執行DML。

查詢記錄

查詢語句返回符合條件記錄,典型是SELECT,可選參數為占位符:

package main

import (
	"database/sql"
	"fmt"
	"log"

	_ "github.com/mattn/go-sqlite3"
)

func main() {

	db, err := sql.Open("sqlite3", "test.db")

	if err != nil {
		log.Fatal(err)
	}

	defer db.Close()

	rows, err := db.Query("SELECT * FROM cars")

	if err != nil {
		log.Fatal(err)
	}

	defer rows.Close()

	for rows.Next() {

		var id int
		var name string
		var price int

		err = rows.Scan(&id, &name, &price)

		if err != nil {
			log.Fatal(err)
		}

		fmt.Printf("%d %s %d\n", id, name, price)
	}
}

執行查詢語句:

rows, err := db.Query("SELECT * FROM cars")

Next為Scan方法準備下一個結果行。成功返回True,如果沒有結果或發生錯誤返回false。

	for rows.Next() {

		var id int
		var name string
		var price int

		err = rows.Scan(&id, &name, &price)

		if err != nil {
			log.Fatal(err)
		}

		fmt.Printf("%d %s %d\n", id, name, price)
	}

Scan方法獲取字段值,最后打印記錄的列值。

帶參數的prepared 語句

使用prepared 語句,可以包括占位符代替直接在語句中寫值,保證數據庫操作的性能和安全。

package main

import (
    "database/sql"
    "fmt"
    "log"

    _ "github.com/mattn/go-sqlite3"
)

func main() {

    db, err := sql.Open("sqlite3", "test.db")

    if err != nil {
        log.Fatal(err)
    }

    defer db.Close()

    stm, err := db.Prepare("SELECT * FROM cars WHERE id = ?")

    if err != nil {
        log.Fatal(err)
    }

    defer stm.Close()

    var id int
    var name string
    var price int

    cid := 3

    err = stm.QueryRow(cid).Scan(&id, &name, &price)

    if err != nil {
        log.Fatal(err)
    }

    fmt.Printf("%d %s %d\n", id, name, price)
}

使用prepare函數執行prepare語句查詢特定行:

stm, err := db.Prepare("SELECT * FROM cars WHERE id = ?")

傳入參數給QueryRow函數,以替換占位符:

err = stm.QueryRow(cid).Scan(&id, &name, &price)

也可以一步實現上面兩步功能:

row := db.QueryRow("SELECT * FROM cars WHERE id = ?", cid)

返回影響行數

RowsAffected 返回執行DML語句影響的行數:

package main

import (
    "database/sql"
    "fmt"
    "log"

    _ "github.com/mattn/go-sqlite3"
)

func main() {

    db, err := sql.Open("sqlite3", "test.db")

    if err != nil {
        log.Fatal(err)
    }

    defer db.Close()

    res, err := db.Exec("DELETE FROM cars WHERE id IN (1, 2, 3)")

    if err != nil {
        log.Fatal(err)
    }

    n, err := res.RowsAffected()

    if err != nil {
        log.Fatal(err)
    }

    fmt.Printf("The statement has affected %d rows\n", n)
}

上面示例使用delete語句刪除三行記錄,然后打印結果進行驗證。運行結果如下:

$ go run main.go 
The statement has affected 3 rows

關于“Golang怎么操作sqlite3數據庫”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“Golang怎么操作sqlite3數據庫”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

探索| 泸西县| 台中县| 文昌市| 平利县| 巴里| 宁明县| 恩平市| 临清市| 个旧市| 巨野县| 高雄县| 辰溪县| 化隆| 石柱| 信阳市| 柯坪县| 鄂尔多斯市| 宜章县| 尼玛县| 铁岭县| 新巴尔虎左旗| 广河县| 河间市| 垣曲县| 尤溪县| 江油市| 建水县| 洛川县| 仁寿县| 南部县| 盱眙县| 北票市| 峨山| 嘉黎县| 涪陵区| 瓮安县| 靖安县| 沈阳市| 镇康县| 乌拉特中旗|