Bel*_*lga 0 c# database asp.net parameters duplicates
问题:插入数据库时数据会重复.如何在数据库中不重复输入?
我通过不使用来阅读有关保护/防止SQL注入的内容
texboxt1.text
Run Code Online (Sandbox Code Playgroud)
所以我尝试使用
parameters.add()
Run Code Online (Sandbox Code Playgroud)
但是每次插入都会复制条目.
这是数据库的图像......

这是我的代码
protected void Button1_Click(object sender, EventArgs e)
{
string username = txtuser.Text;
string firstname = txtfirst.Text;
string lastname = txtlast.Text;
string email = txtemail.Text;
string password = txtpass.Text;
string gender = rbgender.Text;
string nationality = ddcountry.Text;
string Connect_string = ConfigurationManager.ConnectionStrings["connectionString"].ConnectionString;
SqlConnection Connect = new SqlConnection(Connect_string);
Connect.Open();
string pass = FormsAuthentication.HashPasswordForStoringInConfigFile(password, "MD5");
SqlCommand Command = new SqlCommand("INSERT INTO [Users] (username, firstname, lastname, email, password, gender, nationality) VALUES (@username, @firstname, @lastname, @email, @password, @gender, @nationality)", Connect);
Command.Parameters.AddWithValue("@username", username);
Command.Parameters.AddWithValue("@firstname", firstname);
Command.Parameters.AddWithValue("@lastname", lastname);
Command.Parameters.AddWithValue("@email", email);
Command.Parameters.AddWithValue("@password", pass);
Command.Parameters.AddWithValue("@gender", gender);
Command.Parameters.AddWithValue("@nationality", nationality);
Command.ExecuteNonQuery();
int success = Command.ExecuteNonQuery();
if (success > 0)
{
Label1.ForeColor = System.Drawing.ColorTranslator.FromHtml("#12223");
Label1.Visible = true;
Label1.Text = "You have successfully registered";
Connect.Close();
}
else
{
Label1.Text = "Your information has not been entered to database";
Connect.Close();
}
Run Code Online (Sandbox Code Playgroud)
当我使用INSERT INTO表()VALUE'"+ textbox1.text +"时,它不会重复但是,SQL注入 - 东西.
你有两次调用ExecuteNonQuery实际触发命令:
Command.Parameters.AddWithValue("@nationality", nationality);
Command.ExecuteNonQuery(); //CALLED HERE First Time
int success = Command.ExecuteNonQuery(); //CALLED HERE Second Time (This is the one you want)
if (success > 0)
{
Label1.ForeColor = System.Drawing.ColorTranslator.FromHtml("#12223");
Label1.Visible = true;
Label1.Text = "You have successfully registered";
Connect.Close();
}
Run Code Online (Sandbox Code Playgroud)