構文は次のとおりです
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);
结果
服务器为每个连接的客户端维护一系列会话变量。在客户端连接时,使用相应全局变量的当前值对客户端的会话变量进行初始化。设置会话变量不需要特殊权限,但客户端只能更改自己的会话变量,而不能更改其它客户端的会话变量。会话变量的作用域与用户变量一样,仅限于当前连接
#设置会话变量有如下三种方式: 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#要设置一个全局变量,有如下两种方式:
set global var_name = value;
set @@global.var_name = value; //同上
#要想查看一个全局变量,有如下两种方式:
select @@global.var_name;
show global variables like "%var%";
方法 2rrreeecol_name (sid など) が複数行の値を返す場合、@a は値の最後の行のみに移動します。最後に。
ローカル変数は、通常、ストアド プロシージャの開始/終了などの SQL ステートメント ブロックで使用されます。そのスコープはステートメント ブロックに限定されます。ステートメント ブロックが実行されると、ローカル変数は消えます。ローカル変数は通常、declare で宣言され、default を使用してデフォルト値を示すことができます。
rrreeeユーザー変数のスコープ は以下より大きいですローカル変数の範囲が広いこと。ユーザー変数は現在の接続全体に作用しますが、現在の接続が切断されると、その接続によって定義されたユーザー変数は消えます。
ユーザー変数は次の方法で定義されます: @変数名
🎜
以上がmysql の変数の詳細な紹介の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。