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开发,所以在发在首页分享一下,别扔砖头啊~)

posted @ 2009-01-11 21:19  Aaron@Live  阅读(2002)  评论(2编辑  收藏  举报