繁体   English   中英

如何在这种情况下创建if else语句?

[英]How can I create an if else statement with this situatiion?

我想要一个命令,如果我不输入任何内容或返回null值,它将不会执行我的插入命令。 我的代码是这样的:

SqlCommand cmd = con.CreateCommand();
cmd.CommandText = "INSERT INTO Records ([Student ID], [First Name], 
                    [Last Name], [Middle Initial], Gender, Address, Status, 
                    Year, Email, Course, [Contact Number])
                   VALUES    (  @StudentID,  @FirstName, @LastName ,
                         @MiddleInitial,  @Gender, @Address, @Status, @Year,  
                         @Email, @Course, @ContactNumber)";


        SqlParameter p1 = new SqlParameter("@StudentID", SqlDbType.NChar);
        p1.Value = textBox1.Text;
        cmd.Parameters.Add(p1);
        SqlParameter p2 = new SqlParameter("@FirstName", SqlDbType.NVarChar);
        p2.Value = textBox2.Text;
        cmd.Parameters.Add(p2);
        SqlParameter p3 = new SqlParameter("@LastName", SqlDbType.NVarChar);
        p3.Value = textBox3.Text;
        cmd.Parameters.Add(p3);
        SqlParameter p4 = new SqlParameter("@MiddleInitial", SqlDbType.NChar);
        p4.Value = comboBox1.Text;
        cmd.Parameters.Add(p4);
        SqlParameter p5 = new SqlParameter("@Gender", SqlDbType.NChar);
        p5.Value = comboBox2.Text;
        cmd.Parameters.Add(p5);
        SqlParameter p6 = new SqlParameter("@Address", SqlDbType.VarChar);
        p6.Value = textBox4.Text;
        cmd.Parameters.Add(p6);
        SqlParameter p7 = new SqlParameter("@Status", SqlDbType.NChar);
        p7.Value = comboBox3.Text;
        cmd.Parameters.Add(p7);
        SqlParameter p8 = new SqlParameter("@Year", SqlDbType.VarChar);
        p8.Value = comboBox4.Text;
        cmd.Parameters.Add(p8);
        SqlParameter p9 = new SqlParameter("@Email", SqlDbType.VarChar);
        p9.Value = textBox5.Text;
        cmd.Parameters.Add(p9);
        SqlParameter p10 = new SqlParameter("@Course", SqlDbType.VarChar);
        p10.Value = comboBox5.Text;
        cmd.Parameters.Add(p10);
        SqlParameter p11 = new SqlParameter("@ContactNumber", SqlDbType.VarChar);
        p11.Value = textBox6.Text;
        cmd.Parameters.Add(p11);

        textBox1.Text = "";
        textBox2.Text = "";
        textBox3.Text = "";
        textBox4.Text = "";
        textBox5.Text = "";
        textBox6.Text = "";
        comboBox1.Text = "";
        comboBox2.Text = "";
        comboBox3.Text = "";
        comboBox4.Text = "";
        comboBox5.Text = "";
        MessageBox.Show("Data Inserted!", "Information ... ", MessageBoxButtons.OK, MessageBoxIcon.Information, MessageBoxDefaultButton.Button1); 
        cmd.ExecuteNonQuery();
        con.Close();

当您尝试插入空值时可以在表中生成约束,并且可以在程序中获取异常。

另一种选择是循环并检查cmd.Parameters上参数中的所有值,如果发现一个null,nothing或blank,则不应将插入内容发送到数据库。

您可以检查如下

if(!string.IsNullOrEmpty(TextBox1.Text) && !string.IsNullOrEmpty(TextBox2.Text) && !string.IsNullOrEmpty(TextBox3.Text))
{
  // your code

}

如果要避免字符串仅包含" "类的空格,则可以使用string.IsNullOrWhiteSpace方法(在.NET 4.0及string.IsNullOrWhiteSpace版本上可用)

参数是一个集合。 要检查其某些值是否为空:

if (cmd.Parameters.Contains(System.DBNull.Value))
{
   // A parameter has a null value
}

如Damith所建议的,您可以使用string.IsNullOrWhiteSpace或编写一个单独的验证函数来验证文本框中的数据。

    bool Validate()
    {
        if (!string.IsNullOrWhiteSpace(TextBox1.Text) && !string.IsNullOrWhiteSpace(TextBox2.Text)) // For textboxes that need validation
        {
            return true;
        }
        return false;
    }

而不是使用这些if else语句,请查看Contracts。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM