// Copyright (c) 2004-2008 MySQL AB, 2008-2009 Sun Microsystems, Inc. // // This program is free software; you can redistribute it and/or modify // it under the terms of the GNU General Public License version 2 as published by // the Free Software Foundation // // There are special exceptions to the terms and conditions of the GPL // as it is applied to this software. View the full text of the // exception in file EXCEPTIONS in the directory of this software // distribution. // // This program is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // // You should have received a copy of the GNU General Public License // along with this program; if not, write to the Free Software // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA using System.Data; using MySql.Data.MySqlClient; using System.Text; namespace MySql.Data.MySqlClient { /// /// Helper class that makes it easier to work with the provider. /// public sealed class MySqlHelper { private static string stringOfBackslashChars = "\u005c\u00a5\u0160\u20a9\u2216\ufe68\uff3c"; private static string stringOfQuoteChars = "\u0027\u0060\u00b4\u02b9\u02ba\u02bb\u02bc\u02c8\u02ca\u02cb\u02d9\u0300\u0301\u2018\u2019\u201a\u2032\u2035\u275b\u275c\uff07"; // this class provides only static methods private MySqlHelper() { } #region ExecuteNonQuery /// /// Executes a single command against a MySQL database. The is assumed to be /// open when the method is called and remains open after the method completes. /// /// object to use /// SQL command to be executed /// Array of objects to use with the command. /// public static int ExecuteNonQuery( MySqlConnection connection, string commandText, params MySqlParameter[] commandParameters ) { //create a command and prepare it for execution MySqlCommand cmd = new MySqlCommand(); cmd.Connection = connection; cmd.CommandText = commandText; cmd.CommandType = CommandType.Text; if (commandParameters != null) foreach (MySqlParameter p in commandParameters) cmd.Parameters.Add( p ); int result = cmd.ExecuteNonQuery(); cmd.Parameters.Clear(); return result; } /// /// Executes a single command against a MySQL database. A new is created /// using the given. /// /// to use /// SQL command to be executed /// Array of objects to use with the command. /// public static int ExecuteNonQuery( string connectionString, string commandText, params MySqlParameter[] parms ) { //create & open a SqlConnection, and dispose of it after we are done. using (MySqlConnection cn = new MySqlConnection(connectionString)) { cn.Open(); //call the overload that takes a connection in place of the connection string return ExecuteNonQuery(cn, commandText, parms ); } } #endregion #region ExecuteDataSet /// /// Executes a single SQL command and returns the first row of the resultset. A new MySqlConnection object /// is created, opened, and closed during this method. /// /// Settings to be used for the connection /// Command to execute /// Parameters to use for the command /// DataRow containing the first row of the resultset public static DataRow ExecuteDataRow( string connectionString, string commandText, params MySqlParameter[] parms ) { DataSet ds = ExecuteDataset( connectionString, commandText, parms ); if (ds == null) return null; if (ds.Tables.Count == 0) return null; if (ds.Tables[0].Rows.Count == 0) return null; return ds.Tables[0].Rows[0]; } /// /// Executes a single SQL command and returns the resultset in a . /// A new MySqlConnection object is created, opened, and closed during this method. /// /// Settings to be used for the connection /// Command to execute /// containing the resultset public static DataSet ExecuteDataset(string connectionString, string commandText) { //pass through the call providing null for the set of SqlParameters return ExecuteDataset(connectionString, commandText, (MySqlParameter[])null); } /// /// Executes a single SQL command and returns the resultset in a . /// A new MySqlConnection object is created, opened, and closed during this method. /// /// Settings to be used for the connection /// Command to execute /// Parameters to use for the command /// containing the resultset public static DataSet ExecuteDataset(string connectionString, string commandText, params MySqlParameter[] commandParameters) { //create & open a SqlConnection, and dispose of it after we are done. using (MySqlConnection cn = new MySqlConnection(connectionString)) { cn.Open(); //call the overload that takes a connection in place of the connection string return ExecuteDataset(cn, commandText, commandParameters); } } /// /// Executes a single SQL command and returns the resultset in a . /// The state of the object remains unchanged after execution /// of this method. /// /// object to use /// Command to execute /// containing the resultset public static DataSet ExecuteDataset(MySqlConnection connection, string commandText) { //pass through the call providing null for the set of SqlParameters return ExecuteDataset(connection, commandText, (MySqlParameter[])null); } /// /// Executes a single SQL command and returns the resultset in a . /// The state of the object remains unchanged after execution /// of this method. /// /// object to use /// Command to execute /// Parameters to use for the command /// containing the resultset public static DataSet ExecuteDataset(MySqlConnection connection, string commandText, params MySqlParameter[] commandParameters) { //create a command and prepare it for execution MySqlCommand cmd = new MySqlCommand(); cmd.Connection = connection; cmd.CommandText = commandText; cmd.CommandType = CommandType.Text; if (commandParameters != null) foreach (MySqlParameter p in commandParameters) cmd.Parameters.Add( p ); //create the DataAdapter & DataSet MySqlDataAdapter da = new MySqlDataAdapter(cmd); DataSet ds = new DataSet(); //fill the DataSet using default values for DataTable names, etc. da.Fill(ds); // detach the MySqlParameters from the command object, so they can be used again. cmd.Parameters.Clear(); //return the dataset return ds; } /// /// Updates the given table with data from the given /// /// Settings to use for the update /// Command text to use for the update /// containing the new data to use in the update /// Tablename in the dataset to update public static void UpdateDataSet( string connectionString, string commandText, DataSet ds, string tablename ) { MySqlConnection cn = new MySqlConnection( connectionString ); cn.Open(); MySqlDataAdapter da = new MySqlDataAdapter( commandText, cn ); MySqlCommandBuilder cb = new MySqlCommandBuilder(da); cb.ToString(); da.Update( ds, tablename ); cn.Close(); } #endregion #region ExecuteDataReader /// /// Executes a single command against a MySQL database, possibly inside an existing transaction. /// /// object to use for the command /// object to use for the command /// Command text to use /// Array of objects to use with the command /// True if the connection should be preserved, false if not /// object ready to read the results of the command private static MySqlDataReader ExecuteReader(MySqlConnection connection, MySqlTransaction transaction, string commandText, MySqlParameter[] commandParameters, bool ExternalConn ) { //create a command and prepare it for execution MySqlCommand cmd = new MySqlCommand(); cmd.Connection = connection; cmd.Transaction = transaction; cmd.CommandText = commandText; cmd.CommandType = CommandType.Text; if (commandParameters != null) foreach (MySqlParameter p in commandParameters) cmd.Parameters.Add( p ); //create a reader MySqlDataReader dr; // call ExecuteReader with the appropriate CommandBehavior if (ExternalConn) { dr = cmd.ExecuteReader(); } else { dr = cmd.ExecuteReader(CommandBehavior.CloseConnection); } // detach the SqlParameters from the command object, so they can be used again. cmd.Parameters.Clear(); return dr; } /// /// Executes a single command against a MySQL database. /// /// Settings to use for this command /// Command text to use /// object ready to read the results of the command public static MySqlDataReader ExecuteReader(string connectionString, string commandText) { //pass through the call providing null for the set of SqlParameters return ExecuteReader(connectionString, commandText, (MySqlParameter[])null); } /// /// Executes a single command against a MySQL database. /// /// Settings to use for this command /// Command text to use /// Array of objects to use with the command /// object ready to read the results of the command public static MySqlDataReader ExecuteReader(string connectionString, string commandText, params MySqlParameter[] commandParameters) { //create & open a SqlConnection MySqlConnection cn = new MySqlConnection(connectionString); cn.Open(); try { //call the private overload that takes an internally owned connection in place of the connection string return ExecuteReader(cn, null, commandText, commandParameters, false ); } catch { //if we fail to return the SqlDatReader, we need to close the connection ourselves cn.Close(); throw; } } #endregion #region ExecuteScalar /// /// Execute a single command against a MySQL database. /// /// Settings to use for the update /// Command text to use for the update /// The first column of the first row in the result set, or a null reference if the result set is empty. public static object ExecuteScalar(string connectionString, string commandText) { //pass through the call providing null for the set of MySqlParameters return ExecuteScalar(connectionString, commandText, (MySqlParameter[])null); } /// /// Execute a single command against a MySQL database. /// /// Settings to use for the command /// Command text to use for the command /// Parameters to use for the command /// The first column of the first row in the result set, or a null reference if the result set is empty. public static object ExecuteScalar(string connectionString, string commandText, params MySqlParameter[] commandParameters) { //create & open a SqlConnection, and dispose of it after we are done. using (MySqlConnection cn = new MySqlConnection(connectionString)) { cn.Open(); //call the overload that takes a connection in place of the connection string return ExecuteScalar(cn, commandText, commandParameters); } } /// /// Execute a single command against a MySQL database. /// /// object to use /// Command text to use for the command /// The first column of the first row in the result set, or a null reference if the result set is empty. public static object ExecuteScalar(MySqlConnection connection, string commandText) { //pass through the call providing null for the set of MySqlParameters return ExecuteScalar(connection, commandText, (MySqlParameter[])null); } /// /// Execute a single command against a MySQL database. /// /// object to use /// Command text to use for the command /// Parameters to use for the command /// The first column of the first row in the result set, or a null reference if the result set is empty. public static object ExecuteScalar(MySqlConnection connection, string commandText, params MySqlParameter[] commandParameters) { //create a command and prepare it for execution MySqlCommand cmd = new MySqlCommand(); cmd.Connection = connection; cmd.CommandText = commandText; cmd.CommandType = CommandType.Text; if (commandParameters != null) foreach (MySqlParameter p in commandParameters) cmd.Parameters.Add( p ); //execute the command & return the results object retval = cmd.ExecuteScalar(); // detach the SqlParameters from the command object, so they can be used again. cmd.Parameters.Clear(); return retval; } #endregion #region Utility methods /// /// Escapes the string. /// /// The string to escape /// The string with all quotes escaped. public static string EscapeString(string value) { StringBuilder sb = new StringBuilder(); foreach (char c in value) { if (stringOfQuoteChars.IndexOf(c) >= 0 || //sb.Append(c); //else if ( stringOfBackslashChars.IndexOf(c) >= 0) sb.Append("\\"); sb.Append(c); } return sb.ToString(); } public static string DoubleQuoteString(string value) { StringBuilder sb = new StringBuilder(); foreach (char c in value) { if (stringOfQuoteChars.IndexOf(c) >= 0) sb.Append(c); else if (stringOfBackslashChars.IndexOf(c) >= 0) sb.Append("\\"); sb.Append(c); } return sb.ToString(); } #endregion } }