У меня есть CustomValidator, который проверяет, соответствует ли текст, введенный в текстовые поля, определенным полям в базе данных. Раньше все это прекрасно работало, но с тех пор я немного изменил свою страницу, и она больше не работает. Я не думал, что изменил что-нибудь, что могло бы повлиять на это, но, видимо, я это сделал. Все остальные мои валидаторы (обязательные валидаторы полей) работают правильно, но мой CustomValidator не отвечает.
Так вот, вот мой код:
CustomValidator:
<asp:CustomValidator ID="CustomValidator1" runat="server" ControlToValidate="txtCoursePrefix" ErrorMessage="Course number is already taken."></asp:CustomValidator>
VB код:
Protected Sub CustomValidator1_ServerValidate(ByVal source As Object, ByVal args As System.Web.UI.WebControls.ServerValidateEventArgs) Handles CustomValidator1.ServerValidate
'Checking for duplicate course numbers
'get values
Dim checkPrefix = txtCoursePrefix.Text
Dim checkNum = txtCourseNum.Text
'db connectivity
Dim myConn As New OleDbConnection
myConn.ConnectionString = AccessDataSource2.ConnectionString
myConn.Open()
'select records
Dim mySelect As New OleDbCommand("SELECT 1 FROM tableCourse WHERE prefix=? AND course_number=?", myConn)
mySelect.Parameters.AddWithValue("@checkPrefix", checkPrefix)
mySelect.Parameters.AddWithValue("@checkNum", checkNum)
'execute(Command)
Dim myValue = mySelect.ExecuteScalar()
'check if record exists
If myValue IsNot Nothing Then
CustomValidator1.SetFocusOnError = True
args.IsValid = False
End If
End Sub
Все работает до CustomValidator1.SetFocusOnError = True и args.IsValid = False. Я проверил оператор If, и он работает правильно, он возвращает true, и все, что я помещаю в него, выполняется.