mysql存储过程中 乱码问题解决办法

来源:互联网 发布:产品数据管理软件pdm 编辑:程序博客网 时间:2024/04/28 23:21
中文乱码无论在何时都是一个头疼的问题,mysql的存储过程参数也同样存在这个问题。
1、直接使用insert into语句没问题,能够正常插入汉字。
2、把insert into语句移到Procedure中后,就无法插入汉字了。在客户端软件中插入的汉字总是为乱码,英文和数字没问题。
3、如果在jdbc中调用这个Procedure总是报错:

在查阅了很多相关资料后,发现只需要改动procedure的参数的定义就OK了,改动为:在varchar参数后面加入: character set 指定编码。由于服务器编码为gbk,我指定为:

declare  v_title varchar(200)  character set gbk

再执行插入时就不会乱码了


写个完整的 存储过程 供参考

create procedure copyDevTO_authKey()
    begin
          DECLARE var_userId int;
          DECLARE var_authkey varchar(512) character set gbk;
          DECLARE done INT DEFAULT 0;

          DECLARE cur_device CURSOR FOR select  userId,authkey from tbl_device;
          DECLARE CONTINUE HANDLER FOR SQLSTATE '02000' SET done = 1;
          SET done = 0;
          OPEN cur_device;
               -- loop  cursor
             FETCH cur_device INTO var_userId , var_authkey;
             WHILE done <> 1 DO
                      insert into tbl_user_authkey values (var_userId , var_authkey);
                      FETCH cur_device INTO var_userId , var_authkey;
             END WHILE;
           CLOSE cur_device;
    end



原创粉丝点击