mysql使用存储过程插入数据后,参数为中文的为?或乱码

Posted 临飞

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql使用存储过程插入数据后,参数为中文的为?或乱码相关的知识,希望对你有一定的参考价值。

最近了解了一下mysql存储过程,之前版本的mysql不支持存储过程,5.0版本后就可以支持存储过程的使用;恰好笔者下载使用版本为5.6.20:

 

做了一个给表插入数据的简单存储过程,发现打开表后汉字全部显示为?号。如下:

 

于是上网查资料,忙了两小时才搞定!好了,现在简单叙述一下。

笔者遇见的问题是由两种原因引起的;

第一:使用Navicat数据库客户端建立表设置问题导致的,如下:

将上边操作完成后,可以在表里插入汉字,没有?号或者乱码现象了,本以为问题解决了,但使用存储过程时依然插入的是?号;然后笔者就认为是存储过程出问题啦,果然,经查阅资料发现,mysql存储过程插入参数涉及中文的要将varchar类型修改为nvarchar,代码如下:

好了,打完收工!结果如下:

以上方法是笔者找到的两种问题,并将之处理的方案,如读者有其他更好的解决方案,也可以提出来,相互进步;当然类似的问题可能由于其他原因导致,在这里就不过多叙述了!

以上是关于mysql使用存储过程插入数据后,参数为中文的为?或乱码的主要内容,如果未能解决你的问题,请参考以下文章

如何给SQLSERVER存储过程传递数组参数

mysql存储过程实现数据查询与插入

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

无法将参数发送到 MySQL 存储过程窗口窗体

利用mysql存储过程循环插入新数据并更新

MySQL 连接器/Python 存储过程插入未提交