Эта программа требует от пользователя выбрать номер своей карты из поля со списком, а затем ввести свой пароль. Если их пароль совпадает с паролем в базе данных, они входят в систему. Проблема в том, что мой код не выбирает одного конкретного пользователя, он берет только первого пользователя в базе данных, я не могу войти в систему любого другого пользователя, потому что я не Я не знаю, как написать код, который выбирает конкретного пользователя.
Вот что я написал до сих пор. Я думаю, проблема в функции RetrivAccountInformation(). Где-то там мне нужен код, указывающий, что он извлекает данные CardNumber, выбранные в поле со списком cboAccountNumbers. Любая помощь приветствуется.
Импортирует MySql.Данные
Импортирует MySql.Data.MySqlClient
Форма публичного класса1
Dim dbCon As MySqlConnection
Dim strQuery As String = ""
Dim SQLcmd As MySqlCommand
Dim DataReader As MySqlDataReader
Private m_strPass As String
Private m_decBalance As Decimal
Private m_strName As String
Private m_strUserPass As String
Private m_strCardNumber As String
Private Sub Button2_Click(sender As Object, e As EventArgs) Handles btnLogin.Click
'Assign users guessed password to variable
m_strUserPass = txtPass.Text
RetrieveAccountInformation() ' invoke
' determine if PIN number is within valid range
If m_strUserPass = m_strPass Then
lblWelcome.Text = "Hi"
Else
' indicate that incorrect password was provided
lblWelcome.Text = "Sorry, Password the is incorrect." _
& "Please re-enter the password ."
' clear user's previous PIN entry
m_strUserPass = ""
End If
txtPass.Clear() ' clear TextBox
End Sub
' load application Form
Private Sub Form1_Load(sender As System.Object, e As System.EventArgs) Handles MyBase.Load
'Prepare connection and query
Try
dbCon = New MySqlConnection("Server=localhost;Database=test;Uid=root;Pwd=mysql")
strQuery = "SELECT CardNumber " &
"FROM Account"
SQLcmd = New MySqlCommand(strQuery, dbCon)
'Open the connection
dbCon.Open()
' create database reader to read information from database
DataReader = SQLcmd.ExecuteReader
' fill ComboBox with account numbers
While DataReader.Read
cboAccountNumbers.Items.Add(DataReader("CardNumber"))
End While
'Close the connection
DataReader.Close()
dbCon.Close()
Catch ex As Exception
'Output error message to user with explaination of error
MsgBox("Failure to communicate" & vbCrLf & vbCrLf & ex.Message)
End Try
End Sub
' invoke when user provides account number
Private Sub RetrieveAccountInformation()
' specify account number of record from which data
' will be retrieved
dbCon = New MySqlConnection("Server=localhost;Database=***;Uid=***;Pwd=***")
strQuery = "SELECT Password, Name, Balance " &
"FROM Account"
SQLcmd = New MySqlCommand(strQuery, dbCon)
dbCon.Open() ' open database connection
' create database reader to read information from database
DataReader = SQLcmd.ExecuteReader
DataReader.Read() ' open data reader connection
' retrieve PIN number, balance amount and first name
' information from database
m_strPass = Convert.ToString(DataReader("Password"))
m_decBalance = Convert.ToDecimal(DataReader("Balance"))
m_strName = Convert.ToString(DataReader("Name"))
DataReader.Close() ' close data reader connection
dbCon.Close() ' close database connection
End Sub ' RetrieveAccountInformation
Конец класса