ホームページ > バックエンド開発 > Golang > golang はストアド プロシージャを呼び出します

golang はストアド プロシージャを呼び出します

王林
リリース: 2023-05-13 10:45:37
オリジナル
951 人が閲覧しました

Golang では、database/sql パッケージを使用してデータベースに接続し、操作できます。ストアド プロシージャを呼び出す必要がある場合は、通常の SQL ステートメントの呼び出しとは異なり、データベース/SQL パッケージによって提供されるいくつかの特別な関数を使用してストアド プロシージャを呼び出す必要があります。

ストアド プロシージャは、パラメータを受け入れることができる、プリコンパイルされた SQL ステートメントのセットです。これらは通常、複雑なデータ操作を実行するために使用され、効率とセキュリティを向上させることができます。

Golang では、Open() メソッドを通じてデータベース接続を確立できます。次に、Exec() または Query() メソッドを使用して、ストアド プロシージャを含む SQL ステートメントを実行できます。ただし、ストアド プロシージャを呼び出すには、いくつかの特別な処理が必要です。

以下では、Golang でストアド プロシージャを呼び出す方法を紹介します。

まず、Golang でデータベースへの接続を作成する必要があります。以下に示すように、database/sql パッケージによって提供される Open() メソッドを使用して、MySQL データベースへの接続を作成できます。

package main

import (
    "database/sql"
    _ "github.com/go-sql-driver/mysql"
    "log"
)

func main() {

    // Establish a database connection
    db, err := sql.Open("mysql", "user:password@/dbname")
    if err != nil {
        log.Fatal(err)
    }
    defer db.Close()

    // Other database code goes here...

}
ログイン後にコピー

次に、ストアド プロシージャを呼び出す SQL ステートメントを準備する必要があります。 MySQL では、次のように CALL ステートメントを使用してストアド プロシージャを呼び出すことができます。

CALL stored_proc(?, ?)
ログイン後にコピー

"stored_proc" はストアド プロシージャの名前で、疑問符 (?) はパラメータを表します。ここでパラメーターの特定の値を指定することはできませんが、コードの後半で指定します。

SQL ステートメントを準備した後、Prepare() メソッドを使用してプリペアド ステートメント オブジェクトを作成できます。プリペアド ステートメント オブジェクトは、必要に応じてパラメータに渡して実行できるコンパイルされたステートメントです。以下に示すように:

stmt, err := db.Prepare("CALL stored_proc(?, ?)")
if err != nil {
    log.Fatal(err)
}
defer stmt.Close()
ログイン後にコピー

次に、パラメータの値を指定する必要があります。以下に示すように、プリペアド ステートメント オブジェクトの Exec() または Query() メソッドを使用して SQL ステートメントを実行できます。

res, err := stmt.Exec("value1", "value2")
if err != nil {
    log.Fatal(err)
}
ログイン後にコピー

このメソッドは、指定されたパラメーターでストアド プロシージャを実行し、結果を返します。 Exec() メソッドは sql.Result オブジェクトを返します。このオブジェクトを使用して、影響を受ける行の数などの情報を確認できます。

ストアド プロシージャが結果セットを返す場合、以下に示すように、プリペアド ステートメント オブジェクトの Query() メソッドを使用できます。

rows, err := stmt.Query("value1", "value2")
if err != nil {
    log.Fatal(err)
}
defer rows.Close()

// Process the result set here...
ログイン後にコピー

このメソッドはストアド プロシージャを実行し、結果を返します。セット。必要に応じて結果セットを処理できます。

最後に、以下に示すように、データベース接続、準備されたステートメント オブジェクト、結果セットなどのリソースを必要に応じて閉じる必要があります。

stmt.Close()
rows.Close()
db.Close()
ログイン後にコピー

上記は、stored ステートメントを呼び出すための基本的な手順です。 Golang での手順。プリペアド ステートメント オブジェクトを使用すると、SQL インジェクションなどのセキュリティ問題を効果的に回避でき、効率も向上します。

一般に、Golang でのストアド プロシージャの呼び出しは複雑ではありません。データベース/SQL パッケージによって提供されるプリペアド ステートメント オブジェクトを使用して、ストアド プロシージャを実行できます。複雑なデータ操作が必要な状況では、ストアド プロシージャを使用すると効率とセキュリティが大幅に向上します。

以上がgolang はストアド プロシージャを呼び出しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート