mysql里的变量怎么用 mysql中定义变量

mysql 变量设置问题

mysql变量的术语分类:

创新互联主要从事做网站、成都网站设计、网页设计、企业做网站、公司建网站等业务。立足成都服务来安,10年网站建设经验,价格优惠、服务专业,欢迎来电咨询建站服务:18980820575

1.用户变量:以"@"开始,形式为"@变量名"

用户变量跟mysql客户端是绑定的,设置的变量,只对当前用户使用的客户端生效

2.全局变量:定义时,以如下两种形式出现,set

GLOBAL

变量名

或者

set

@@global.变量名,对所有客户端生效。只有具有super权限才可以设置全局变量

3.会话变量:只对连接的客户端有效。

4.局部变量:作用范围在begin到end语句块之间。在该语句块里设置的变量

declare语句专门用于定义局部变量。set语句是设置不同类型的变量,包括会话变量和全局变量

通俗理解术语之间的区别:

用户定义的变量就叫用户变量。这样理解的话,会话变量和全局变量都可以是用户定义的变量。只是他们是对当前客户端生效还是对所有客户端生效的区别了。所以,用户变量包括了会话变量和全局变量

局部变量与用户变量的区分在于两点:

1.

用户变量是以"@"开头的。局部变量没有这个符号。

2.

定义变量不同。用户变量使用set语句,局部变量使用declare语句定义

3.

作用范围。局部变量只在begin-end语句块之间有效。在begin-end语句块运行完之后,局部变量就消失了。

所以,最后它们之间的层次关系是:变量包括局部变量和用户变量。用户变量包括会话变量和全局变量。

使用备忘,set

@var

若没有指定GLOBAL

或SESSION

,那么默认将会定义用户变量

两种方式定义用户变量:

1."=",如

set

@a

=3,@a:=5

2.":="。select常常这样使用

总结:使用select

和set设置变量的区别,set可以使用以上两种形式设置变量。而select只能使用":="的形式设置变量

实践积累:用户变量在mysql客户端退出后,会自动消失。之后我打开客户端,使用"select

@a;"

显示变了的值为null。说明,未定义的变量初始化是null

实际中的问题

设置常量对group_concat()的配置影响:

SET

@@GROUP_CONCAT_MAX_LEN=4

手册中提到设置的语法是这样的:

SET

[SESSION

|

GLOBAL]

group_concat_max_len

=

val;

以下两种形式都能达到达到同样的效果,但是有什么区别?

SET

@@global.GROUP_CONCAT_MAX_LEN=4;

global可以省略,那么就变成了:SET

@@GROUP_CONCAT_MAX_LEN=4;

2011.2.25

之前的理解不怎么准确。现在对加深理解后的地方进行总结。

mysql中变量的层次关系是:大体包括用户变量和系统变量。系统变量包括系统会话变量和系统全局变量。

相互之间的区别:

因为用户变量就是用户定义的变量,系统变量就是mysql定义和维护的变量。所以,用户变量与系统变量的区别在于,是谁在管理这些变量。mysql一启动的时候就会读取系统变量(这样做目的是可以确定mysql的以何种机制或模式运行)。

系统会话变量与用户变量都是在当前客户端退出后消失。他们之间的区别可以这样理解,虽然常常看到"set

@@varible"的形式去改变系统变量的值,但是并不涉及到定义系统变量。用户变量是可以自己定义(初始化)。系统变量按照只是在改变值。

局部变量只在begin-end语句块中定义并有效。执行到该语句块之后就消失了。定义的方式有明显的特点,使用declare语句。

使用系统变量理论上是可以使用两种形式:

1.

前面带有符号"@@"

2.

符号省略。比如我会看的如下形式:CURRENT_USER。但是,约定系统变量要使用"@@变量名"的形式,就是在前面加上符号"@@"

如何使用变量向mysql中插入数据

在select 语句中赋值给用户变量的语法是 @ var_name := value ,这里的var_name 是变量名,value是正检索的值.

1:变量可以用在以后语句中表达式可用的任何地方,例如where字句或者insert 语句中。

例如select @id :=cust_id from customers where cust_id='customer name';

delete from orders where cust_id = @id;

2:变量的另一个用途是保存在一个auto_increment列的表中 插入新的一行后last_insert_id()的结果

select @last_id :=Last_INSERT_ID();

LAST_INSERT_ID()返回新的AUTO_INCREMENT列值,通过将其保存在变量中,你可以在之后的语句中多次引用该值。

即使发起其他的语句创建他们自身的atuo_increment值,从而改变了last_insert_id()返回的值

3:用户变量拥有单一的值,如果使用返回多行的语句来将值赋给一个变量,那么只有最后一行的值被赋给了该变量。

4:要将一个变量显示地设为一个特定值,使用set语句,set语法可以使用:=或者=来进行赋值

5:set也可以用来将一个select的结果赋给一个变量.

mysql里面是怎么试用表变量的

mysql有临时表:create temporary table if not exists {表定义}--关键字”temporary“指示mysql创建会话级别的临时表。

临时表只对当前会话可见,连接断开时,自动删除!

你不必担心所创建的临时表的名称会和其他会话建立的临时表、或非临时表冲突!注意如果你的临时表和正常表名称相同,正常表会被隐藏——如同全局变量和局部变量那样

创建临时表不会引发通常的commit事务提交

使用临时表的诸多限制

引擎类型只能是:memory(heap)、myisam、merge、innodb

不支持mysql cluster

同一个查询语句中只能引用一次! 如 SELECT * FROM TP_TABLE , TP_TABLE AS ALIAS_NAME;是错误的

同一个用户存储函数中只能引用一次!

show tables 不会显示临时表

不能使用rename重命名临时表。只能使用ALTER TABLE OLD_TP_TABLE_NAME RENAME NEW_TP_TABLE_NAME;

影响使用replication功能

mysql服务器自动使用的内部临时表

在某些情况下,mysql服务器会自动创建内部临时表:该临时表可以是只存在于内存的memory临时表,或者是存储于硬盘的myisam临时 表;而且 初始创建的memory临时表由于表的增大 可能会转变为myisam临时表——其转化临界点由max_heap_table_size 和tmp_table_size系统变量的 较小值 决定的!注意:max_heap_table_size系统变量应用于所有的memory引擎的表,不管是用户临时表、正常表、或者内部临时表。

内部临时表的创建条件:

group by 和 order by中的列不相同

order by的列不是引用from 表列表中 的第一表

group by的列不是引用from 表列表中 的第一表

使用了sql_small_result选项

含有distinct 的 order by语句

初始创建内部myisam临时表的条件:

表中存在text、blob列

在group by中的 列 有超过512字节

在distinct查询中的 列 有超过512字节

在union、union all联合查询中,select 列 列表中的 列 有超过512字节的

如何判断某个查询是否会产生内部临时表:使用explain查看执行计划,检查extra列看是否使用临时表“using temporary”

mysql补充:局部变量

mysql中各种类型变量的定义以及赋值使用

MySQL中实现rank排名查询

# 1、局部变量(即@开头的变量)

在一个会话内,只须初始化一次,之后在会话内都是对 上一次计算的结果 ,就相当于在是这个会话内的全局变量。

mysql中局部变量不用事前申明,在用的时候直接用“@变量名”使用就可以了。

# 2、语法

初始值赋值 :

使用

注意:

使用set时可以用“=”或“:=”,但是使用select时必须用“:=赋值”

如果直接写:select @name:=password from user;

如果这个查询返回多个值的话,那@name变量的值就是最后一条记录的password字段的值 。

题目1:根据学生的年年龄进行排序,相同年龄的学生为一组,组内编号依次为1,2,3...

实现:一个字段内部的排序。

MySQL中row_number的实现

通常,用group by 可以实现一个字段的聚合,再结合order by进行排序。但是在一个字段内部不同的'值'再聚合并排序,就不是group by能够做到的了。

此处可以使用局部变量实现自增,给字段内不同value 使用case...when...进行条件判断后打上标签,也就实现了排序功能。

使用

具体运行过程成:

另一种用户变量的初始赋值技巧:

得到相同的运行结果

题目2:按各科成绩进行排序,并显示排名, Score 重复时也继续排名

set @i:=0,@j:=null

select sid,cid,@i:=if(@i=@j,@i,@i+1) as stu_rank,@j:=score as stu_score

from sc

order by stu_score desc

方法一:case ...when...

另一种初始赋值形式也可以写成:

运行结果:

方法二:if(exp1,exp2,exp3)

另一种初始赋值形式也可以写成:

运行结果:

题目中的要求要简单些,不需要判断是否与上一行相等,一直继续排序即可。相当于根据成绩排名后添加行号。

运行结果:

MYSQL中使用存储过程中,变量怎么使用?

create procedure p

@a char(15)

as

begin

insert into @a (name)

values ('zhangsan')

end

Mysql中如何使用变量?

String sql="SELECT * FROM `test`.`changetalbe` where HZ= @temp ;";

改为

String sql="SELECT * FROM `test`.`changetalbe` where HZ="+temp;

你原来那句话里temp后面也多一个空格。连接变量要用+号的。不能写在语句内部,好像那是C#的语法。


新闻名称:mysql里的变量怎么用 mysql中定义变量
分享链接:http://scyanting.com/article/hhjdgo.html