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读取完数据之后, 再读一个字符串的字段;