MySQL和Oracle的变量

时间:2021-12-13 02:03:08

MySQL和Oracle的变量

正好手边方便,电脑上装了MySQL,学校主机上有Oracle,可以两个环境都试一试

变量分两种,系统变量和用户变量

MySQL

来源:https://blog.csdn.net/J080624/article/details/73828012

【1】系统变量
系统定义好的变量,大部分时候用户根本不需要使用系统变量。系统变量是用来控制服务器表现的。如:autocommit,auto_increment_increment等。

① 查看系统变量

--查看所有变量
show variables;

--查看范围变量
show variables like ‘%变量名%‘;
修改系统变量

修改系统变量有两种方式:会话级别和全局级别。

会话级别
临时修改,当前客户端当次连接有效,关闭将会恢复默认值。

有说法称为会话变量,属于系统变量子集,区别与用户变量!

set 变量名 = 变量值;

or

set @@变量名 = 变量值;
1
2
3
4
5
示例如下:

set autocommit = 0;

set @@ autocommit = 0;
全局级别
一次修改,永久生效(对所有客户端都生效)。

set global 变量名 = 值;
1
示例如下:

set GLOBAL autocommit = 1;
1
当前客户端修改后需要关闭连接重新打开,即可看到生效。

如果对方(其他)客户端当前已经连接上服务器,那么当次修改无效,要退出重新登录才会生效。
④ 变量单位

不同的变量的单位不同,比如table_cache是指缓存的表的个数,而key_buffer_size则是以字节为单位,另外还有以页或者百分比为单位的变量。

许多变量可以通过后缀制订单位,比如1M表示一百万字节,在配置文件中或者在命令行下有效。但是在使用set命令的时候,这些单位就无效,必须使用数字,单位为字节。
比如:

set @@session.sort_buffer_size = 1024*1024
或者
set @@session.sort_buffer_size = 1048576
1
2
3

但是配置文件中设置的时候就不能使用表达式。

来源:https://blog.csdn.net/JesseYoung/article/details/40779631

1 用户变量介绍
用户变量即用户自己定义的变量,我们可以给用户变量分配值,并且可用在任何可以正常使用标量表达式的地方。
引入用户变量之前我们必须使用set语句或select语句来定义它,然后为它赋一个值,否则变量就只有一个空值。
用户变量与连接有关。也就是说,一个客户端定义的变量不能被其它客户端看到或使用。当客户端退出时,该客户端连接的所有变量将自动释放。
2 用户变量定义
set语句可用于向系统变量或用户变量赋值,针对用户变量的定义如下:
SET @var_name = expr [, @var_name = expr] ...
也可使用select语句来定义:
SELECT @var_name := expr [, @var_name = expr] ...
用户变量:以"@"开始,形式为"@var_name",以区分用户变量及列名。它可以是任何随机的,复合的标量表达式,只要其中没有列指定。
一个变量名可以由当前字符集的数字字母字符和“_”、“$”和“.”组成。缺省字符集是ISO-8859-1 Latin1;这可以用mysqld 的--default-character-set 选项更改字符集。
对于SET,可以使用=或:=来赋值,对于SELECT只能使用:=来赋值。、查看用户变量

查看变量使用select语句

select @name;

用户变量没有删除指令,退出客户端自动释放。

Oracle

来源:https://blog.csdn.net/wahaa591/article/details/46772769

1、define(即host变量)

define variable_name = value

显示指定的DEFINE变量值和类型

//使用define def_name命令显示指定DEFINE变量的值和类型(DEFINE变量类型都为char)
SQL> define num;
DEFINE num              = "1" (CHAR)

2、Variable(即绑定变量)

绑定变量主要是在sql中使用,达到sql解析一次,执行多次,从而提高效率的目的。绑定变量和host变量一样,也有定义的,也有临时性的。(临时性的在动态sql或动态plsql中通过占位符和using使用),其他的如sql会自动使用绑定变量的情况,此处不专门讨论。定义的绑定变量也是在当前session中有效。 绑定变量以下特点:

绑定变量在sql和plsql中直接引用必须加前缀 :。如要引用绑定变量a,则是 :a;

在真正运行的PLSQL程序中,比如自动运行,有自己的一套机制;

初始化和应用绑定变量,初始化定义的绑定变量,可以使用过程和函数,其中过程可以内部给绑定变量赋值、也可以参数是绑定变量,参数模式为out返回。使用函数和过程差不多,还可以使用call
函数来赋值。

sqlplus中可以使用大于等于3个字符表示一个命令,这里我们用var,var命令是声明一个绑定变量,只能给予名称和类型,定义的时候不能赋值,赋值可以在plsql中或者采用函数赋值(而host变量定义的时候必须赋值)。
(1).语法:

var var_name type
(2).声明绑定变量

//使用var声明两number类型的变量num1、num2
SQL> var num1 number;
SQL> var num2 number;

(3).显示指定绑定变量

//var num1命令显示指定绑定变量名称、数据类型
SQL> var num1
variable num1
datatype NUMBER

SQL>