ストアド プロシージャ内で SQL ログインを動的に作成するにはどうすればよいですか?
Dec 16, 2024 pm 10:13 PM動的パラメーターを使用した CREATE LOGIN
動的パラメーターを使用してストアド プロシージャ内で SQL ログインを作成しようとすると、開発者は「'@username 付近の構文が正しくありません」というエラーが発生する場合があります。 「。」この不可解なメッセージは誤解を招き、混乱を招く可能性があります。
根本的な問題は、CREATE LOGIN ステートメントがパラメーターではなくリテラルのユーザー名のみを受け入れることです。この制限を回避するには、次の回避策を採用する必要があります。
- 動的 SQL コマンドを構築する: 必要なユーザー名とパスワードを含む CREATE LOGIN ステートメントを含む SQL コマンド文字列を構築します。
- 動的 SQL を実行します: EXEC を使用します。コマンドを使用して、動的に構築された SQL 文字列を実行し、SQL ログインを動的に作成します。
この回避策を実装する方法の例を次に示します。
DECLARE @sql nvarchar(max) = 'CREATE LOGIN ' + quotename(@username) + ' WITH PASSWORD = ' + quotename(@password, ''''); EXEC(@sql)
このコードは、最初に動的SQL コマンド文字列。SQL インジェクション攻撃に対する安全性を確保するために、ユーザー名とパスワードが引用符で囲まれていることを確認します。次に、EXEC ステートメントを使用して動的 SQL コマンドを実行し、SQL ログインを作成します。
このアプローチを採用することで、開発者は CREATE LOGIN がリテラルのみを受け入れるという制限を克服し、ストアド プロシージャ内に SQL ログインを動的に作成できます。
以上がストアド プロシージャ内で SQL ログインを動的に作成するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

人気の記事

人気の記事

ホットな記事タグ

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











Alter Tableステートメントを使用してMySQLのテーブルをどのように変更しますか?

Linuxでmysqlを実行します(phpmyAdminを使用してポッドマンコンテナを使用して/なし)

MACOSで複数のMySQLバージョンを実行する:ステップバイステップガイド

共通の脆弱性(SQLインジェクション、ブルートフォース攻撃)に対してMySQLを保護するにはどうすればよいですか?

MySQL接続用のSSL/TLS暗号化を構成するにはどうすればよいですか?
