ホームページ > データベース > mysql チュートリアル > mysql の変数の詳細な紹介

mysql の変数の詳細な紹介

零下一度
リリース: 2017-05-09 13:30:07
オリジナル
1388 人が閲覧しました

変数を定義する

構文は次のとおりです

declare var_name[,...] type [default value];
ログイン後にコピー

MYSQL 変数の定義は、Oracle/SQL Server とは異なり、ストアド プロシージャ または 関数 でのみ定義できます。この変数のスコープは、begin...end ブロック内のみにすることができます。変数定義は、複合ステートメントの先頭で、他のステートメントの前に記述する必要があります。同じ型の複数の変数を一度に宣言できます。 default を使用してデフォルト値を割り当てることができます。 declare はローカル変数定義でのみ使用できます。 declare只能用在局部变量定义中。

#举例
declare v_test int default 10;
ログイン後にコピー

设置变量

方式一

set var_name=expr,[,var_name2=expr ...];

#举例
set v_test=15;
ログイン後にコピー

方式二

select col_name[,...] into var_name[,...] table_expr;

#举例
select sid into @a from test1;
ログイン後にコピー

如果col_name(如sid)返回多行值,@a最后只会去最后一行值。

变量分类

局部变量(不需要加@)

局部变量一般用在sql语句块中,比如存储过程的begin/end。其作用域仅限于该语句块,在该语句块执行完毕后,局部变量就消失了。局部变量一般用declare来声明,可以使用default来说明默认值。

create procedure add(in a int,in b int)
begin
    declare c int default 0;#c定义的局部变量
    set c = a + b;
    select c as c;
end;
ログイン後にコピー

用户变量(一个@)

用户变量的作用域要比局部变量要广。用户变量可以作用于当前整个连接,但是当当前连接断开后,其所定义的用户变量都会消失。
用户变量使用如下的方式定义:@变量名

#举例
set @a = 1;
set @b = 2;
select @sum:=(@a + @b), @dif:=(@a - @b);
ログイン後にコピー

结果

mysql の変数の詳細な紹介

用户变量

会话变量(两个@@)

服务器为每个连接的客户端维护一系列会话变量。在客户端连接时,使用相应全局变量的当前值对客户端的会话变量进行初始化。设置会话变量不需要特殊权限,但客户端只能更改自己的会话变量,而不能更改其它客户端的会话变量。会话变量的作用域与用户变量一样,仅限于当前连接

#设置会话变量有如下三种方式:
set session var_name = value;
set @@session.var_name = value;
set var_name = value;

#查看一个会话变量也有如下三种方式:
select @@var_name;
select @@session.var_name;
show session variables like "%var%";
ログイン後にコピー

変数を設定する

方法 1

方法 2rrreeecol_name (sid など) が複数行の値を返す場合、@a は値の最後の行のみに移動します。最後に。 変数の分類

ローカル変数 (@を付ける必要はありません)

ローカル変数は、通常、ストアド プロシージャの開始/終了などの SQL ステートメント ブロックで使用されます。そのスコープはステートメント ブロックに限定されます。ステートメント ブロックが実行されると、ローカル変数は消えます。ローカル変数は通常、declare で宣言され、default を使用してデフォルト値を示すことができます。

rrreee

ユーザー変数 (@ 1 つ)

ユーザー変数のスコープ は以下より大きいですローカル変数の範囲が広いこと。ユーザー変数は現在の接続全体に作用しますが、現在の接続が切断されると、その接続によって定義されたユーザー変数は消えます。
ユーザー変数は次の方法で定義されます: @
変数名

rrreee🎜Result
🎜

mysql の変数の詳細な紹介
🎜

ユーザー変数 🎜🎜🎜セッション変数 (2 つの @@) 🎜🎜🎜 サーバーは、接続されているクライアントごとに一連のセッション変数を維持します。クライアントが接続すると、クライアントのセッション変数は、対応するグローバル変数の現在の値を使用して初期化されます。セッション変数の設定には特別な権限は必要ありませんが、クライアントは独自のセッション変数のみを変更でき、その他の 🎜 クライアント セッション変数。 セッション変数の有効範囲はユーザー変数と同じで、現在の接続に限定されます。現在の接続が切断されると、その接続によって設定されたすべてのセッション変数が無効になります。 🎜rrreee🎜🎜グローバル変数 (2 つの @@)🎜🎜🎜 グローバル変数はサーバーの全体的な動作に影響します。サーバーが起動すると、すべてのグローバル変数がデフォルト値に初期化されます。これらのデフォルト値は、オプション ファイルまたはコマンド ラインで指定されたオプションによって変更できます。グローバル変数を変更するには、🎜SUPER🎜権限が必要です。グローバル変数はサーバーの🎜ライフサイクル🎜全体に影響しますが、再起動をまたがることはできません。つまり、再起動後は、設定されているすべてのグローバル変数が無効になります。再起動後もグローバル変数を引き続き有効にするには、対応する🎜設定ファイル🎜を変更する必要があります。 🎜rrreee🎜注: ここの global は省略できません。マニュアルによると、setコマンドで変数を設定する際にGLOBAL、SESSION、LOCALのいずれかを指定しないとデフォルトでSESSIONが使用されるとのこと。 🎜🎜【関連する推奨事項】🎜🎜1. 🎜無料のmysqlオンラインビデオチュートリアル🎜🎜🎜2. 🎜MySQLの最新マニュアルチュートリアル🎜🎜🎜3. 🎜ブール教育ヤンシバmysql入門ビデオチュートリアル🎜🎜

以上がmysql の変数の詳細な紹介の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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