您的位置:首页 > 数据库 > MySQL

[MySQL] SQL语句中文别名乱码问题

2008-08-05 17:44 846 查看
MySQL 驱动下载地址: http://www.mysql.com/products/connector/, 根据自己的使用选择下载

我使用的是ASP.NET, 将下载的驱动解压, 建一个空白WEB项目, 然后引用解压出来的 MySql.Data.dll, 添加一个 test.aspx 文件

test.aspx.vb 文件代码如下:
Imports System.Data
Imports System.Data.Common
Imports MySql.Data.MySqlClient

Partial Class test
Inherits System.Web.UI.Page

Protected Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load
Dim connection As MySqlConnection
connection = New MySqlConnection("Server=localhost;Database=webanalytics;Uid=root;Pwd=;CharSet=utf8;")
connection.Open()

doTest(New MySqlCommand("select AutoId as `2自动编号4` from Site", connection))
doTest(New MySqlCommand("select `Id` as `desc描述222` from Site;", connection))
doTest(New MySqlCommand("select `Domain` as `3域名2domain` from Site;", connection))
doTest(New MySqlCommand("select `Explain` as `desc描述` from Site;", connection))

connection.Close()
connection.Dispose()
End Sub

Private Sub doTest(ByVal cmd As DbCommand)
Dim reader As DbDataReader = cmd.ExecuteReader()
response.Write("<h3>" & reader.GetName(0) & "</h3>")
While reader.Read
response.Write("<p>" & reader.GetValue(0))
End While
reader.Close()
cmd.Dispose()
End Sub
End Class
在浏览器中查看结果如下:



注:最后一条数据在数据库中就是乱码

经反复测试, 发现问题出现在 DbDataReader, 如果只使用DbDataReader.GetName()获取字段的别名将不会现现乱码, 当读取了数据时, 并且最后一次读取的是非字符串类型, 那么下次(没有关闭连接对象)再次使用DbDataReader读取字段别名时会出现乱码(当然别名得是中文).

这样有以下方案可以解决.
1. 每次使用完 DbDataReader 后关闭连接, 再重新打开;
2. DbDataReader读取完数据之后, 再读一个字符串的字段;
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐