Asp.Net + MySql 开发笔记 第一回:乱码
因为项目需要,这回得用 MySql做数据库。对MySql虽说久闻大名,但却从未谋面,看来这回要来个亲密接触了!
下载、安装、建数据库,一切顺利。然后就是这么连接数据库了,在网上查了资料,下载了MySql.Data.DLL ,按照网上说的连接字符串写法(和mssql差不多:Server=myServerAddress;Database=myDataBase;Uid=myUsername;Pwd=myPassword;),顺利连上MySql数据库,兴奋了一把!
然后测试数据的读写,开始随便敲了几个字符,也一切正常,然后录了几个中文,这下傻眼了,执行了Insert后再Select出来,全成立问号“???”!一看数据库,数据库里也是问号了,这回麻烦来了,没法,只有求助网络,Google一搜,到是出来不少,但是很多都是一样,而且几乎没找到完整的解决方案,没法,就一个一个的试。
经过一番折腾,最后终于试出解决办法:
建数据库时选择默认字符集为:utf-8
在连接字符串里加上:charset=utf8 (Server=myServerAddress;Database=myDataBase;Uid=myUsername;Pwd=myPassword;charset=utf8)
测试成功,因为我的Web.Config里的设置是: requestEncoding="UTF-8" responseEncoding="UTF-8"
按照这个测试,如果要用GB2312编码,估计就得把数据库的编码,连接字符串的编码以及request和response的编码都修改为gb2312才行(这个还没测试,因为我的项目要求用utf8)。
附各数据库的连接字符串写法示例网站:http://www.connectionstrings.com/
(由于第一次做MySql开发,所以在发在首页分享一下,别扔砖头啊~)