mysql使用存储过程插入数据后,参数为中文的为?或乱码
Posted 临飞
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql使用存储过程插入数据后,参数为中文的为?或乱码相关的知识,希望对你有一定的参考价值。
最近了解了一下mysql存储过程,之前版本的mysql不支持存储过程,5.0版本后就可以支持存储过程的使用;恰好笔者下载使用版本为5.6.20:
做了一个给表插入数据的简单存储过程,发现打开表后汉字全部显示为?号。如下:
于是上网查资料,忙了两小时才搞定!好了,现在简单叙述一下。
笔者遇见的问题是由两种原因引起的;
第一:使用Navicat数据库客户端建立表设置问题导致的,如下:
将上边操作完成后,可以在表里插入汉字,没有?号或者乱码现象了,本以为问题解决了,但使用存储过程时依然插入的是?号;然后笔者就认为是存储过程出问题啦,果然,经查阅资料发现,mysql存储过程插入参数涉及中文的要将varchar类型修改为nvarchar,代码如下:
好了,打完收工!结果如下:
以上方法是笔者找到的两种问题,并将之处理的方案,如读者有其他更好的解决方案,也可以提出来,相互进步;当然类似的问题可能由于其他原因导致,在这里就不过多叙述了!
以上是关于mysql使用存储过程插入数据后,参数为中文的为?或乱码的主要内容,如果未能解决你的问题,请参考以下文章