How to insert Records in Database using C# language?

前端 未结 6 2020
孤独总比滥情好
孤独总比滥情好 2020-12-01 17:26

I am just a begginer on C# so i need too much help. Now the problem is that i have designed a windows form in which there are many fields like first name, last name, address

相关标签:
6条回答
  • 2020-12-01 17:50

    There are many problems in your query.
    This is a modified version of your code

    string connetionString = null;
    string sql = null;
    
    // All the info required to reach your db. See connectionstrings.com
    connetionString = "Data Source=UMAIR;Initial Catalog=Air; Trusted_Connection=True;" ;
    
    // Prepare a proper parameterized query 
    sql = "insert into Main ([Firt Name], [Last Name]) values(@first,@last)";
    
    // Create the connection (and be sure to dispose it at the end)
    using(SqlConnection cnn = new SqlConnection(connetionString))
    {
        try
        {
           // Open the connection to the database. 
           // This is the first critical step in the process.
           // If we cannot reach the db then we have connectivity problems
           cnn.Open();
    
           // Prepare the command to be executed on the db
           using(SqlCommand cmd = new SqlCommand(sql, cnn))
           {
               // Create and set the parameters values 
               cmd.Parameters.Add("@first", SqlDbType.NVarChar).Value = textbox2.text;
               cmd.Parameters.Add("@last", SqlDbType.NVarChar).Value = textbox3.text;
    
               // Let's ask the db to execute the query
               int rowsAdded = cmd.ExecuteNonQuery();
               if(rowsAdded > 0) 
                  MessageBox.Show ("Row inserted!!" + );
               else
                  // Well this should never really happen
                  MessageBox.Show ("No row inserted");
    
           }
        }
        catch(Exception ex)
        {
            // We should log the error somewhere, 
            // for this example let's just show a message
            MessageBox.Show("ERROR:" + ex.Message);
        }
    }
    
    • The column names contain spaces (this should be avoided) thus you need square brackets around them
    • You need to use the using statement to be sure that the connection will be closed and resources released
    • You put the controls directly in the string, but this don't work
    • You need to use a parametrized query to avoid quoting problems and sqlinjiection attacks
    • No need to use a DataAdapter for a simple insert query
    • Do not use AddWithValue because it could be a source of bugs (See link below)

    Apart from this, there are other potential problems. What if the user doesn't input anything in the textbox controls? Do you have done any checking on this before trying to insert? As I have said the fields names contain spaces and this will cause inconveniences in your code. Try to change those field names.

    This code assumes that your database columns are of type NVARCHAR, if not, then use the appropriate SqlDbType enum value.

    Please plan to switch to a more recent version of NET Framework as soon as possible. The 1.1 is really obsolete now.

    And, about AddWithValue problems, this article explain why we should avoid it. Can we stop using AddWithValue() already?

    0 讨论(0)
  • 2020-12-01 17:53

    You should form the command with the contents of the textboxes:

    sql = "insert into Main (Firt Name, Last Name) values(" + textbox2.Text + "," + textbox3.Text+ ")";
    

    This, of course, provided that you manage to open the connection correctly.

    It would be helpful to know what's happening with your current code. If you are getting some error displayed in that message box, it would be great to know what it's saying.

    You should also validate the inputs before actually running the command (i.e. make sure they don't contain malicious code...).

    0 讨论(0)
  • 2020-12-01 17:55

    You should change your code to make use of SqlParameters and adapt your insert statement to the following

    string connetionString = "Data Source=UMAIR;Initial Catalog=Air; Trusted_Connection=True;" ;
    // [ ] required as your fields contain spaces!!
    string insStmt = "insert into Main ([First Name], [Last Name]) values (@firstName,@lastName)";
    
    using (SqlConnection cnn = new SqlConnection(connetionString))
    {
        cnn.Open();
        SqlCommand insCmd = new SqlCommand(insStmt, cnn);
        // use sqlParameters to prevent sql injection!
        insCmd.Parameters.AddWithValue("@firstName", textbox2.Text);
        insCmd.Parameters.AddWithValue("@lastName", textbox3.Text);
        int affectedRows = insCmd.ExecuteNonQuery();
        MessageBox.Show (affectedRows + " rows inserted!");
    }
    
    0 讨论(0)
  • 2020-12-01 17:57
    sql = "insert into Main (Firt Name, Last Name) values(textbox2.Text,textbox3.Text)";
    

    (Firt Name) is not a valid field. It should be FirstName or First_Name. It may be your problem.

    0 讨论(0)
  • 2020-12-01 18:00

    You should form the command with the contents of the textboxes:

    sql = "insert into Main (Firt Name, Last Name) values(" + textbox2.Text + 
    "," + textbox3.Text+ ")";
    

    This, of course, provided that you manage to open the connection correctly.

    It would be helpful to know what is happening with your current code. If you are getting some error displayed in that message box, it would be great to know what it's saying.

    You should also validate the inputs before actually running the command (i.e. make sure they don't contain malicious code).

    0 讨论(0)
  • 2020-12-01 18:12

    Use a parameterized query to prevent Sql injections (secutity problem)

    Use the using statement so the connection will be closed and resources will be disposed.

    using(var connection = new SqlConnection("connectionString"))
    {
        connection.Open();
        var sql = "INSERT INTO Main(FirstName, SecondName) VALUES(@FirstName, @SecondName)";
        using(var cmd = new SqlCommand(sql, connection))
        {
            cmd.Parameters.AddWithValue("@FirstName", txFirstName.Text);
            cmd.Parameters.AddWithValue("@SecondName", txSecondName.Text);
    
            cmd.ExecuteNonQuery();
        }
    }
    
    0 讨论(0)
提交回复
热议问题