MySQL写存储过程时报错

MySQL写存储过程时报错,第1张

1267- Illegal mix of collations (utf8_unicode_ci,IMPLICIT) and (utf8_general_ci,IMPLICIT) for operation '=

问题描述 :

SELECT distinct a.user_id INTO userID FROM authorization_record a WHERE a.open_id = openId AND a.auth_type = '5001'

错误如下:

[Err]1267- Illegal mixofcollations (utf8_unicode_ci,IMPLICIT)and(utf8_general_ci,IMPLICIT)foroperation'='

解决方法 :

将比较等式一边进行字符串转换,如改为“ CONVERT(b.fullCode USING utf8) COLLATE utf8_unicode_ci ”

SELECT distinct a.user_id INTO userID FROM authorization_record a WHERE a.open_id = CONVERT(openId USING utf8) COLLATE utf8_unicode_ci AND a.auth_type = '5001'

create procedure student()

begin

select stu_no from student-- 加个分号

end

-- 如果加了分号还不行的话抄,提示的错误应该是

错误:PLS-00428: 在此 SELECT 语句中缺少 INTO 子句

原因是单独的一个袭select语句在存储过程中是不应该存在的,所以应该改成zhidaoselect stu_no into 的模式

create procedure student()

is

v_stu_no student.stu_no%TYE

begin

select stu_no into v_stu_no from student where rownum <= 1-- 改成select into 字句

end

如果t_kecheng只有2个字段的话,并且数据类型和存储过程输入参数一致的话,存储过程没问题。

mysql的1064错误就是语法不正确,最好给出t_kecheng的表结构,还有,你这个错误是在创建的时候报的还是怎么?

自己简单创建了个表,是没问题的,另外你注意一下:参数名最好不要跟字段名起一样的,有时会出现很多不必要的麻烦,比如如果你t_kecheng表里的字段名也叫pno和pname,那么你参数最好用v_pno或v_pname,这样区分一下。

create table t_kecheng

(pno int,

pname varchar(20)) CREATE PROCEDURE pro

(IN pno INT, 

IN pname VARCHAR(20))

BEGIN 

INSERT INTO t_kecheng VALUES(pno,pname)

END

随便输入点信息也是可以的。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/7090086.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-01
下一篇 2023-04-01

发表评论

登录后才能评论

评论列表(0条)

保存