mysqlset类型是5.6版本。mysqlset函数原型是intmysql_set_character_set(MYSQL*mysql,char*csname)。该函数用于为当前连接设置默认的字符集。字符串csname指定了1个有效的字符集名称。连接校对成为字符集的默认校对。该函数的工作方式与SETNAMES语句类似,但它还能设置mysql-charset的值,从而影响了由mysql_real_escape_string()设置的字符集。该函数是在MySQL5.0.7中增加的。该函数0表示成功,非0值表示出现错误。
专注于为中小企业提供网站设计、成都做网站服务,电脑端+手机端+微信端的三站合一,更高效的管理,为中小企业南陵免费做网站提供优质的服务。我们立足成都,凝聚了一批互联网行业人才,有力地推动了上千多家企业的稳健成长,帮助中小企业通过网站建设实现规模扩充和转变。
MySQL手册中find_in_set函数的语法:
FIND_IN_SET(str,strlist)
str 要查询的字符串
strlist 字段名 参数以”,”分隔 如 (1,2,6,8)
查询字段(strlist)中包含(str)的结果,返回结果为null或记录
假如字符串str在由N个子链组成的字符串列表strlist 中,则返回值的范围在 1 到 N 之间。 一个字符串列表就是一个由一些被 ‘,’ 符号分开的子链组成的字符串。如果第一个参数是一个常数字符串,而第二个是type SET列,则FIND_IN_SET() 函数被优化,使用比特计算。 如果str不在strlist 或strlist 为空字符串,则返回值为 0 。如任意一个参数为NULL,则返回值为 NULL。这个函数在第一个参数包含一个逗号(‘,’)时将无法正常运行。
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存储过程中,定义变量有两种方式:
1.使用set或select直接赋值,变量名以 @ 开头.
例如:set @var=1;
可以在一个会话的任何地方声明,作用域是整个会话,称为会话变量。
2.以 DECLARE 关键字声明的变量,只能在存储过程中使用,称为存储过程变量,例如:
DECLARE var1 INT DEFAULT 0;
主要用在存储过程中,或者是给存储传参数中。
两者的区别是:
在调用存储过程时,以DECLARE声明的变量都会被初始化为 NULL。而会话变量(即@开头的变量)则不会被再初始化,在一个会话内,只须初始化一次,之后在会话内都是对上一次计算的结果,就相当于在是这个会话内的全局变量。
在存储过程中,使用动态语句,预处理时,动态内容必须赋给一个会话变量。
例:
set @v_sql= sqltext;
PREPARE stmt FROM @v_sql;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;
set是修改系统参数或者设置变量用的,例如:
-- 设置字符集为utf8
set GLOBAL character_set_server='utf8';
-- 设置变量等于某个值
set @d=11;
select @d; -- 此处可查到d的值为11
MySQL存储过程中,定义变量有两种方式:
1、使用set或select直接赋值,变量名以@开头,可以在一个会话(即连接)的任何地方声明,作用域是整个会话,称为用户变量。例如:set @var=1;
2、 以declare关键字声明的变量,只能在存储过程中使用,称为存储过程变量,主要用在存储过程中,或者是给存储传参数中。例如: declare var1 int default 0;
两者的区别是:
在调用存储过程时,以declare声明的变量都会被初始化为null。而会话变量(即@开头的变量)则不会被再初始化,在一个会话(连接)内,只须初始化一次,之后在会话内都是对上一次计算的结果,就相当于在是这个会话内的全局变量。