MySQL变量(参数)的查看和设置

类似于Oracle的参数文件,MySQL的选项文件(如my.cnf)用于配置MySQL服务器,但和Oracle叫法不一样,在MySQL里 , 官方叫变量(Varialbes),但其实叫参数也是可以的,只要明白这俩是同一个东西就可以了。

MySQL的变量分为以下两种:

1)系统变量:配置MySQL服务器的运行环境,可以用show variables查看

2)状态变量:监控MySQL服务器的运行状态,可以用show status查看

系统变量

系统变量按其作用域的不同可以分为以下两种:

1)分为全局(GLOBAL)级:对整个MySQL服务器有效

2)会话(SESSION或LOCAL)级:只影响当前会话

有些变量同时拥有以上两个级别,MySQL将在建立连接时用全局级变量初始化会话级变量,但一旦连接建立之后,全 局级变量的改变不会影响到会话级变量。

查看系统变量的值

可以通过show vairables语句查看系统变量的值:

mysql> show variables like 'log%';

mysql> show variables where Variable_name like 'log%' and value='ON';

注意:show variables优先显示会话级变量的值,如果这个值不存在,则显示全局级变量的值,当然你也可以加上 GLOBAL或SESSION关键字区别:

show global variables;

show session/local variables;

在写一些存储过程时,可能需要引用系统变量的值,可以使用如下方法:

@@GLOBAL.var_name
@@SESSION.var_name 或
@@LOCAL.var_name

如果在变量名前没有级别限定符,将优先显示会话级的值。

最后一种查看变量值的方法是从INFORMATION_SCHEMA数据库里的GLOBAL_VARIABLES和SESSION_VARIABLES表获得。

设置和修改系统变量的值

在MySQL服务器启动时,有以下两种方法设置系统变量的值:

1)命令行参数,如:mysqld --max_connections=200

2)选项文件(my.cnf)

在MySQL服务器启动后,如果需要修改系统变量的值,可以通过SET语句:

SET GLOBAL var_name = value;
SET @@GLOBAL.var_name = value;
SET SESSION var_name = value;
SET @@SESSION.var_name = value;

如果在变量名前没有级别限定符,表示修改会话级变量。

注意:和启动时不一样的是,在运行时设置的变量不允许使用后缀字母'K'、‘M'等,但可以用表达式来达到相 同的效果,如:

SET GLOBAL read_buffer_size = 2*1024*1024

状态变量

状态变量可以使我们及时了解MySQL服务器的运行状况,可以使用show status语句查看。

状态变量和相同变量类似,也分为全局级和会话级,show status也支持like匹配查询,比较大的不同是状态变量只 能由MySQL服务器本身设置和修改,对于用户来说是只读的,不可以通过SET语句设置和修改它们。

查看本栏目更多精彩内容:http://www.bianceng.cnhttp://www.bianceng.cn/database/MySQL/

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索mysql
, 服务器
, 变量
, 系统
, 状态
, global variables
, show
, 服务级
, 系统变量
, MySQL变量
, MySql状态查看
, 状态变量
, MySQL运行状态
mysql参数变量
查看mysql参数设置、查看mysql编译参数、mysql 查看参数、mysql 查看变量、mysql 查看配置参数,以便于您获取更多的相关知识。

时间: 2024-11-15 20:53:32

MySQL变量(参数)的查看和设置的相关文章

mysql 查看和设置变量

mysql 查看和设置变量 查看变量 SELECT @@sql_mode 范例: mysql> SELECT @@sql_mode -> ; +-----------------------------------------------+ | @@sql_mode | +-----------------------------------------------+ | ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZER

mysql Key_buffer_size参数的优化设置_Mysql

先来看看document对这个参数的解释: 缓存myisam表的索引块大小,可以被所有进程所共享.当设置key_buffer_size,操作系统不会马上分配key_buffer_size设置的值,而是在需要的时候,再分配的.可以设置多个key_buffer,当设置不是默认key_buffer为0时,mysql会把缓存的索引块移到默认的key_buffer中去并删除不再使用的索引块.Myisam表中只能cache索引块,不能cache数据块. 原本描述: Index blocks for MyIS

对MySQL配置参数 my.ini/my.cnf的详细解析_Mysql

以下的文章主要描述的是对MySQL配置参数 my.ini/my.cnf的详细解析,我们主要是以实例演示的方式来对MySQL配置参数 my.ini/my.cnf的实际操作步骤进行说明,以下就是相关内容的具体描述. 1.获取当前配置参数 要优化MySQL配置参数,首先要了解当前的配置参数以及运行情况.使用下列命令可以获得目前服务器使用的配置参数: 复制代码 代码如下: mysqld –verbose –help mysqladmin variables extended-status –u root

MySQL配置文件之mysql.ini参数详解

  my.ini(Linux系统下是my.cnf),当mysql服务器启动时它会读取这个文件,设置相关的运行环境参数. my.ini分为两块:Client Section和Server Section. Client Section用来配置MySQL客户端参数. 要查看配置参数可以用下面的命令: show variables like '%innodb%'; # 查看innodb相关配置参数 show status like '%innodb%'; # 查看innodb相关的运行时参数(比如当前

MySQL 存储过程参数:in、out、inout

一.MySQL 存储过程参数(in) MySQL 存储过程 "in" 参数:跟 C 语言的函数参数的值传递类似, MySQL 存储过程内部可能会修改此参数,但对 in 类型参数的修改,对调用者(caller)来说是不可见的(not visible). Java代码   drop procedure if exists pr_param_in;   create procedure pr_param_in(       in id int -- in 类型的 MySQL 存储过程参数  

MySQL中SHOW STATUS查看运行状况

直接在命令行下登陆MySQL运行SHOW STATUS; 1, 查看MySQL服务器配置信息    代码如下 复制代码   mysql> show variables; 2, 查看MySQL服务器运行的各种状态值    代码如下 复制代码 mysql> show global status; 3, 慢查询  代码如下 复制代码   mysql> show variables like '%slow%'; +------------------+-------+ | Variable_na

mysql 变量(局部变量/全局变量)使用说明

共同点:不区分大小写,都是变量 不同点:全局变量是系统中只读的,可以在配置文件中进行修改 mysql变量的术语分类: 1.用户变量:以"@"开始,形式为"@变量名" 用户变量跟mysql客户端是绑定的,设置的变量,只对当前用户使用的客户端生效 2.全局变量:定义时,以如下两种形式出现,set GLOBAL 变量名  或者  set @@global.变量名 对所有客户端生效.只有具有super权限才可以设置全局变量 3.会话变量:只对连接的客户端有效. 4.局部变量

详解MySQL存储过程参数有三种类型(in、out、inout)_Mysql

一.MySQL 存储过程参数(in) MySQL 存储过程 "in" 参数:跟 C 语言的函数参数的值传递类似, MySQL 存储过程内部可能会修改此参数,但对 in 类型参数的修改,对调用者(caller)来说是不可见的(not visible). 复制代码 代码如下: drop procedure if exists pr_param_in; create procedure pr_param_in ( in id int -- in 类型的 MySQL 存储过程参数 ) begi

linux date命令查看和设置时间详解

  date命令 date命令的功能是显示和设置系统日期和时间. 该命令的一般格式为: date [选项] 显示时间格式(以+开头,后面接格式) date 设置时间格式 命令中各选项的含义分别为: 代码如下: -d datestr, --date datestr 显示由datestr描述的日期 -s datestr, --set datestr 设置datestr 描述的日期 -u, --universal 显示或设置通用时间 时间域 代码如下: % H 小时(00..23) % I 小时(01