我有一个应用程序,将,除其他事项外,各种数据存储到数据库中。 数据库可能是ORACLE或SQL Server。 SQL是基于配置和执行期间获取的值动态创建的。的DbCommand和参数化的SQL,ORACLE VS SQL服务器
通过使用DbProviderFactory我的分贝方法能够与Oracle或SQL Server一起工作,而无需编写自定义代码对任何数据库,除了从一两件事;参数/绑定变量。对于ORACLE我需要使用":ParameterName"
而对于SQL Server的我需要使用"@ParameterName"
。有没有办法使这个通用?
示例代码:
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();
}
解决方案与正则表达式:http://stackoverflow.com/questions/35063018/parameterized-sql-oracle-vs-sql-server-with-regular-expresion – 2016-01-28 14:37:28