Soldato
		
		- Joined
- 24 Sep 2007
- Posts
- 5,794
Hi Guys
I have some old C# code that I wrote that adds data into a MariaDB using the MySql.Data.MySqlClient namespace.
The problem is I can't add text containing apostrophes into the database properly. I know this is a classic problem, but I can't remember how to fix it, apart from using stored procedures instead, which looks a bit complicated, especially when using MariaDB.
Anyway, my code, and in particular the SQL insert statement, is:
	
	
	
		
What do I need to do to be able to handle apostrophes added in the text fields?
Any suggestions or links to code examples appreciated.
Thanks
	
		
			
		
		
	
				
			I have some old C# code that I wrote that adds data into a MariaDB using the MySql.Data.MySqlClient namespace.
The problem is I can't add text containing apostrophes into the database properly. I know this is a classic problem, but I can't remember how to fix it, apart from using stored procedures instead, which looks a bit complicated, especially when using MariaDB.
Anyway, my code, and in particular the SQL insert statement, is:
		Code:
	
	 try {
            // Open database connection
            // Technique is passing the connection string to the constructor of the MySqlConnection class
            // Note you have to import the MySql.Data.MySqlClient namespace to be able to use this
            MySqlConnection conn = new MySqlConnection(connStr);
            conn.Open();
            // For testing
            // lblMyTestLabel.Text = "Connection Opened!";
            // Get values from web form
            String BrandName = txtBrandName.Text;
            String BrandDesc = txtBrandDesc.Text;
            String BrandUrl = txtBrandUrl.Text;
            String BrandPage = txtBrandPage.Text;
            // Add the brand
            String SqlInsert = "INSERT into brands (BrandName, BrandDesc, BrandUrl, BrandPage) VALUES ('" + BrandName + "', '" + BrandDesc + "', '" + BrandUrl + "', '" + BrandPage + "')";
            // Create a command to run against the database
            MySqlCommand cmd = new MySqlCommand(SqlInsert);
            // Specify the CommandType for the connection, in this case it's text from a string, not a stored procedure
            cmd.CommandType = System.Data.CommandType.Text;
            // Give the MySQLCommand a connection to use
            cmd.Connection = conn;
            // Execute the non query
            cmd.ExecuteNonQuery();
            // Close the connection
            conn.Close();
            // Hide the form
            formBrandAdd.Visible = false;
            // Confirm done
            lblUserMessage.Text = "Brand added! <a href='brand-add.aspx'>Add another</a>";
            lblUserMessage.BackColor = System.Drawing.Color.LightGreen;
            //For testing
            // lblMyTestLabel.Text = "Yes, that's completed! <a href='brand-add.aspx'>Add another brand</a>";
            // lblMyTestLabel.BackColor = System.Drawing.Color.LightGreen;
        }What do I need to do to be able to handle apostrophes added in the text fields?
Any suggestions or links to code examples appreciated.
Thanks
 
	 
  
 
		 
 
		 
					
				 
 
		 
 
		 and a good habit even if writing more casual stuff/prototyping but also far easier said than done.
 and a good habit even if writing more casual stuff/prototyping but also far easier said than done.