MySQL系统变量是MySQL数据库的重要组成部分,下面就为您分析MySQL系统变量的具体应用,如果您对MySQL系统变量感兴趣的话,不妨一看。
MySQL系统变量
比如, 公司的总人数,很多存储过程都需要调用这个值,但是因为这个值,不是经常会改变的,不需要每次都count.
所以大多数人会考虑把它cache一把,那么mysql提供的全局变量,就是一个好的存储场所.
2, 数据库配置中心
首先,这不一定是一种好的解决方式, 特别是大型地分布式系统.但是想到了,就跟大家分享一下.
主要就是利用了三层,四层架构的系统, 必不可少的数据库层来实现的.
大家知道, 应用的配置, 大多数是用配置文件或配置服务器来实现, 前者需要跟着项目打包, 部署.
后者, 只要在应用初始化或运行时,去配置中心取配置就行了.(淘宝这边两者都在用)
而数据库的配置中心, 其实类似配置服务器, 只不过灵活运用了mysql的变量机制.
它能继承配置服务器的多数优点, 但最大的特色就是在 sql, function , procedure 里都可以很方便地引用到.(相比用表的方式, 要方便一些)
并且本身就具有缓存, 移植得话, mysql得导出也是很快.
所以小系统, 想快速得搭建一个配置中心,利用mysql感觉还是不错的.
调用语法:
select * from user_info where id = @@global.admin_id -- 例子,通过全局里配置的管理员id来取用户信息
以下是全局变量的一些常用命令,比较简单:
set global auto_increment_increment=1; -- 设置序列的增长值
show global variables; -- 显示所有的global变量
show global variables like '%test%' -- 查询包含test字符串的global变量
会话系统变量, 主要用于在当前客户端连接的生命周期内.它的变量值是全局变量的一份拷贝.
如果连接断开, 对当前会话变量所做修改都会被重置.
比如, 服务器会话变量 autocommit 默认为 true , 而你在非常连的客户端连接里设置了 false , 那么在执行完sql后, 连接就会断开. 此后,如果创建新的连接来执行sql, autocommit又会默认 true.
会话变量的使用场景与全局类似,只是生命周期不同, 因此可以用来统计同一连接内请求sql次数, sql类型等信息.
session变量的一些常用操作:
set session auto_increment_increment=1; -- 设置序列的增长值
show variables; or show session variables; -- 如果不指明, 默认使用session变量
show variables like '%test%' or show session variables lile '%test%' -- 查询包含test字符串的session变量