Не отображается сообщение об ошибке на Ma c, но отлично работает на windows - PullRequest
0 голосов
/ 21 апреля 2020

Обновление: теперь все функции работают правильно. Он выполняет всю необходимую проверку, кроме Alertmassage (например, ScriptManager.RegisterClientScriptBlock (this, this.GetType (), "alertMessage", "alert ('SSN уже существует, запись обновлена.!')", True);) не отображается на экране. Он отлично работает на windows, но не отображается на Ма c.

protected void BtnBtnInsert_Click(object sender, System.EventArgs e)
{
    MySqlCommand cmd;
    string str;

    MySqlConnection con = new MySqlConnection(ConString);

    int Status = 0;
    con.Open();

    String UpdateQuery;
    String SSN;

    SSN = TxtBxSSSN.Text.ToString().Trim();

    if (CheckValidSSNBeforeUpdate(SSN) == "1")
    {
        ScriptManager.RegisterClientScriptBlock(this, this.GetType(), "alertMessage", "alert('SSN already exists, record is updated.!')", true);
    }
    else
    {
        InsertNewEmployee();  
    }

    con.Close();
} 

public void InsertNewEmployee()
{
    String SSN, SFName, MName, LName, DOB, Address;

    SSN = TxtBxSSSN.Text.ToString().Trim();
    SFName = lblSFanme.Text.ToString().Trim();
    MName = lblMName.Text.ToString().Trim();
    LName = lblLName.Text.ToString().Trim();
    DOB = lblDOB.Text.ToString().Trim();
    Address = lblAddress.Text.ToString().Trim();

    String SSN1 = new String(SSN.Where(x => Char.IsDigit(x)).ToArray());

    String Tmpe = "SSN : " + SSN + " , SFName : " + SFName + " , MName : " + MName + " , LName : " + LName + " , DOB : " + DOB + " , Address : " + Address;

    if (SSN.Length == 0 || SFName.Length == 0 || MName.Length == 0 || LName.Length == 0 || DOB.Length == 0 || Address.Length == 0)
    {
        ScriptManager.RegisterClientScriptBlock(this, this.GetType(), "alertMessage", "alert('Please enter values in all the fields. All fields are mandatory')", true);
    }
    else
    {
        if (SSN1.Length != 9)
        {
            ScriptManager.RegisterClientScriptBlock(this, this.GetType(), "alertMessage", "alert('Invalid SSN, It must be of 9 digits')", true);
        }
        else
        {
            InsertNewEmployeeRecord();
        }
    }
}

public void InsertNewEmployeeRecord()
{
    String SSN, SFName, MName, LName, DOB, Address;

    SSN = TxtBxSSSN.Text.ToString().Trim();
    SFName = lblSFanme.Text.ToString().Trim();
    MName = lblMName.Text.ToString().Trim();
    LName = lblLName.Text.ToString().Trim();
    DOB = lblDOB.Text.ToString().Trim();
    Address = lblAddress.Text.ToString().Trim();

    MySqlCommand cmd;
    string str;

    MySqlConnection con = new MySqlConnection(ConString);

    int Status = 0;
    con.Open();

    String InsertQuery;

    InsertQuery = "Insert Into Employee VALUES ('"+SSN+ "','"+DOB+"','"+SFName+"','"+MName+"','"+LName+"','"+Address+"')";

    cmd = new MySqlCommand(InsertQuery, con);
    cmd.ExecuteNonQuery();

    con.Close();

    ScriptManager.RegisterClientScriptBlock(this, this.GetType(), "alertMessage", "alert('Record inserted successfully.!')", true);
}

1 Ответ

1 голос
/ 23 апреля 2020

В методе «InsertNewEmployeeRecord» у вас есть следующее:

String UpdateQuery;

InsertQuery = "Insert Into Employee VALUES ('"+SSN+ "','"+DOB+"','"+SFName+"','"+MName+"','"+LName+"','"+Address+"')";

cmd = new MySqlCommand(UpdateQuery, con);

Вы объявляете UpdateQuery, затем присваиваете значение InsertQuery и затем выполняете UpdateQuery, который является нулевым.

Так что вам нужно использовать:

 cmd = new MySqlCommand(InsertQuery, con);
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...