Tengo una aplicación que, entre otras cosas, almacenará varios datos en una base de datos. La base de datos puede ser ORACLE o SQL Server. El SQL se crea de forma dinámica en función de la configuración y los valores recogidos durante la ejecución.DbCommand y SQL parametrizado, ORACLE vs SQL Server
Al utilizar DbProviderFactory, mis métodos db pueden funcionar con ORACLE o SQL Server sin escribir código personalizado para ninguna de las bases de datos, excepto por una cosa; parámetros/variables de enlace. Para ORACLE necesito usar ":ParameterName"
mientras que para SQL Server necesito usar "@ParameterName"
. ¿Hay alguna forma de hacer esto genérico?
Código de ejemplo:
public class DbOperations
{
private DbProviderFactory m_factory;
private DbConnection m_CN;
...
private void InsertToDb(ValueType[] values, ColumnType[] columns)
{
DbCommand Cmd = m_factory.CreateCommand();
Cmd.Connection = m_CN;
StringBuilder sql = new StringBuilder();
sql.Append("INSERT INTO ");
sql.Append(DestinationTable);
sql.Append(" (");
for (int i = 0; i < columns.Length; i++)
{
sql.Append(columns[i].ColumnName);
if (i < columns.Length - 1)
sql.Append(", ");
}
sql.Append(") VALUES (");
for (int i = 0; i < values.Length; i++)
{
//sql.Append(String.Format(":{0}", columns[i].ColumnName)); //ORACLE
sql.Append(String.Format("@{0}", columns[i].ColumnName)); // SQL Server
}
DbParameter param = m_factory.CreateParameter();
param.Direction = ParameterDirection.Input;
param.ParameterName = columns[i].ColumnName;
param.Value = values[i];
Cmd.Parameters.Add(param);
if (i < columns.Length - 1)
sql.Append(", ");
}
sql.Append(")");
Cmd.CommandText = sql.ToString();
Cmd.ExecuteNonQuery();
}
solución con expresiones regulares: http://stackoverflow.com/questions/35063018/parameterized-sql-oracle-vs-sql-server-with-regular-expresion –