ホームページ >バックエンド開発 >Golang >Go で SQL クエリの文字列と値を連結するにはどうすればよいですか?

Go で SQL クエリの文字列と値を連結するにはどうすればよいですか?

Linda Hamilton
Linda Hamiltonオリジナル
2024-10-26 17:38:031024ブラウズ

How to Concatenate Strings and Values in SQL Queries in Go?

Go での同等の SQL クエリの連結

Python では、SQL クエリ内の文字列と値の連結は % 演算子を使用することで簡単に行えます。ただし、Go では、このメソッドは期待どおりに機能しない可能性があります。

この問題を解決するには、Go プログラマは fmt.Sprintf 関数を利用できます。次のコード サンプルは、文字列と値を連結する正しい方法を示しています。

<code class="go">query := fmt.Sprintf(`SELECT columnA FROM tableA WHERE columnB = %d AND columnB = %s`, SomeNumber, SomeString)</code>

このメソッドは、値が正しくフォーマットされ、処理されることを保証します。さらに、ユーザーが提供したデータをクエリに埋め込む際には、インジェクション攻撃の潜在的な脆弱性に注意することが重要です。このリスクを軽減するには、次のアプローチの使用を検討してください。

<code class="go">query := `SELECT column_name FROM table_name
    WHERE column1_name = %d AND column2_name = %d`

rows, err := db.Query(query, Val1, Val2)</code>

クエリと値に個別の引数を採用することで、悪意のある入力によるクエリの構造や意図の変更を防ぐことができます。

以上がGo で SQL クエリの文字列と値を連結するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。