存储过程问题,高分在线急求,解决马上给分,不给是小狗 本帖最后由 xiongwenbin 于 2009-11-25 10:28:50 编辑 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 变量的长度问题,更改如下即可:DECLARE sCodeList CHAR; -- 用户代码列表DECLARE sCodeValue CHAR; -------------->>DECLARE sCodeList CHAR(100); -- 用户代码列表DECLARE sCodeValue CHAR(100); 你不定义长度,其默认是1,故会出现“传入'd'正常返回'd',传入'dd'返回null(有问题,只要传入字符长度大于1就返回不了值了) ” 定义长度小了DECLARE sCodeList CHAR(100); -- 用户代码列表 DECLARE sCodeValue CHAR(100); 有@的可以直接使用,不用定义select * into @ee from tt没有@的要定义才能使用,如你的SP DECLARE sCodeList CHAR; 等同于DECLARE sCodeList CHAR(1); char(100)都换成varchar(100)看看! http://dev.mysql.com/doc/refman/5.1/zh/language-structure.html#variables9.3. 用户变量可以先在用户变量中保存值然后在以后引用它;这样可以将值从一个语句传递到另一个语句。用户变量与连接有关。也就是说,一个客户端定义的变量不能被其它客户端看到或使用。当客户端退出时,该客户端连接的所有变量将自动释放。用户变量的形式为@var_name,其中变量名var_name可以由当前字符集的文字数字字符、‘.’、‘_’和‘$’组成。 默认字符集是cp1252 (Latin1)。可以用mysqld的--default-character-set选项更改字符集。参见5.10.1节,“数据和排序用字符集”。用户变量名对大小写不敏感。设置用户变量的一个途径是执行SET语句:SET @var_name = expr [, @var_name = expr] ...对于SET,可以使用=或:=作为分配符。分配给每个变量的expr可以为整数、实数、字符串或者NULL值。也可以用语句代替SET来为用户变量分配一个值。在这种情况下,分配符必须为:=而不能用=,因为在非SET语句中=被视为一个比较 操作符:mysql> SET @t1=0, @t2=0, @t3=0;mysql> SELECT @t1:=(@t2:=1)+@t3:=4,@t1,@t2,@t3;+----------------------+------+------+------+| @t1:=(@t2:=1)+@t3:=4 | @t1 | @t2 | @t3 |+----------------------+------+------+------+| 5 | 5 | 1 | 4 |+----------------------+------+------+------+用户变量可以用于表达式中。目前不包括明显需要文字值的上下文中,例如SELECT语句的LIMIT子句,或者LOAD DATA语句的IGNORE number LINES子句。如果使用没有初始化的变量,其值是NULL。 如何统计mysql字段中有多少个分号? innodb如何转换成myisam mysql 一个表里有多少字段是合适的呢 怎样复制data文件夹备份数据? 急用!!在线等 mysql使用问题!!(在线急切等待ing,给达人送100分) 还是这个mysql的问题啊!我头大啊 这个sql该怎么写? 存储过程游标循环-求助 关于MYSQL中对字段更新为另一字段的自然对数出错 视图与存储过程性能比较?? 求救mysql error:the table is full
DECLARE sCodeList CHAR; -- 用户代码列表DECLARE sCodeValue CHAR;
-------------->>DECLARE sCodeList CHAR(100); -- 用户代码列表DECLARE sCodeValue CHAR(100);
”
DECLARE sCodeList CHAR(100); -- 用户代码列表 DECLARE sCodeValue CHAR(100); 有@的可以直接使用,不用定义
select * into @ee from tt
没有@的要定义才能使用,如你的SP
9.3. 用户变量
可以先在用户变量中保存值然后在以后引用它;这样可以将值从一个语句传递到另一个语句。用户变量与连接有关。也就是说,一个客户端定义的变量不能被其它客户端看到或使用。当客户端退出时,该客户端连接的所有变量将自动释放。用户变量的形式为@var_name,其中变量名var_name可以由当前字符集的文字数字字符、‘.’、‘_’和‘$’组成。 默认字符集是cp1252 (Latin1)。可以用mysqld的--default-character-set选项更改字符集。参见5.10.1节,“数据和排序用字符集”。用户变量名对大小写不敏感。设置用户变量的一个途径是执行SET语句:SET @var_name = expr [, @var_name = expr] ...对于SET,可以使用=或:=作为分配符。分配给每个变量的expr可以为整数、实数、字符串或者NULL值。也可以用语句代替SET来为用户变量分配一个值。在这种情况下,分配符必须为:=而不能用=,因为在非SET语句中=被视为一个比较 操作符:mysql> SET @t1=0, @t2=0, @t3=0;mysql> SELECT @t1:=(@t2:=1)+@t3:=4,@t1,@t2,@t3;+----------------------+------+------+------+| @t1:=(@t2:=1)+@t3:=4 | @t1 | @t2 | @t3 |+----------------------+------+------+------+| 5 | 5 | 1 | 4 |+----------------------+------+------+------+用户变量可以用于表达式中。目前不包括明显需要文字值的上下文中,例如SELECT语句的LIMIT子句,或者LOAD DATA语句的IGNORE number LINES子句。如果使用没有初始化的变量,其值是NULL。