首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >MySqlDataReader生成错误

MySqlDataReader生成错误
EN

Stack Overflow用户
提问于 2010-05-12 13:57:28
回答 2查看 2.5K关注 0票数 1

我在VB.NET中有一个函数,它在启动主应用程序之前对MySQL数据库对用户进行身份验证。下面是函数的代码:

代码语言:javascript
复制
    Public Function authConnect() As Boolean
    Dim dbserver As String
    Dim dbuser As String
    Dim dbpass As String
    dbserver = My.Settings.dbserver.ToString
    dbuser = My.Settings.dbuser.ToString
    dbpass = My.Settings.dbpass.ToString
    conn = New MySqlConnection
    myConnString = "server=" & dbserver & ";" & "user id=" & dbuser & ";" & "password=" & dbpass & ";" & "database=rtadmin"
    Dim myCommand As New MySqlCommand
    Dim myAdapter As New MySqlDataAdapter
    Dim myData As New DataTable
    Dim myDataReader As New MySqlDataReader
    Dim query As String

    myCommand.Parameters.Add(New MySqlParameter("?Username", login_usr_txt.Text))
    myCommand.Parameters.Add(New MySqlParameter("?Password", login_pass_txt.Text))
    query = "select * from users where user = ?Username and passwd = ?Password"
    conn.ConnectionString = myConnString
    Try
        conn.Open()
        Try
            myCommand.Connection = conn
            myCommand.CommandText = query
            myAdapter.SelectCommand = myCommand
            myDataReader = myCommand.ExecuteReader
            If myDataReader.HasRows() Then
                MessageBox.Show("You've been logged in.", "RT Live! Information", MessageBoxButtons.OK, MessageBoxIcon.Information)
            End If
        Catch ex As Exception

        End Try
    Catch ex As Exception

    End Try
End Function    

函数尚未完成,在启动应用程序之前还需要做一些其他的事情,因为我使用MessageBox来显示登录尝试的结果。

我得到的错误如下:

'MySql.Data.MySqlClient.MySqlDataReader.Friend错误1

Sub New(cmd作为MySql.Data.MySqlClient.MySqlCommand,语句为MySql.Data.MySqlClient.PreparableStatement,行为为System.Data.CommandBehavior)在此上下文中无法访问,因为它是“朋友”。C:\User\Mario\documents\visual studio 2010\Projects\Remote Techs Live!\Remote Techs Live!\Login.vb 43 13远程技术直播!

有什么想法吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2010-05-12 14:19:31

尝试创建一个MySqlDataReader然后扔掉它是没有意义的!

首先,您要尝试创建一个读取器:

代码语言:javascript
复制
    Dim myDataReader As New MySqlDataReader

然后,当你这样做的时候,你试着扔掉它:

代码语言:javascript
复制
    myDataReader = myCommand.ExecuteReader

只需从初始声明中删除New。我怀疑MySqlDataReader的构造函数是不可公开访问的。

票数 1
EN

Stack Overflow用户

发布于 2010-05-12 14:03:02

您可以尝试.AddWithValue而不是.Add。

例如:

代码语言:javascript
复制
cmd.Parameters.AddWithValue("?Username", login_usr_txt.Text)
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/2819445

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档