跪求:将整个DataTable的数据插入到Oracle方法

commemoration 2012-04-13 02:12:11
DataTable dt = new DataTable();
dt.Columns.Add("ID", typeof(int));
dt.Columns.Add("Name", typeof(string));
......
如上,数据都已经添加到DataTable中了,求插入到Oracle的方法啊,知道SQL中有SqlBulkCopy方法可以,Oracle怎么方法是怎样的?谢谢啊!

...全文
260 1 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
qldsrx 2012-04-13
  • 打赏
  • 举报
回复
这是我自己写的,同时兼容Sqlserver和Oracle的复制数据方法:

public static void TableCopy(DataTable dt, string dTableName, IDbConnection conn, IDbTransaction tran)
{
if (conn is SqlConnection)
{
SqlBulkCopy sbc = new SqlBulkCopy((SqlConnection)conn);
sbc.DestinationTableName = dTableName;
sbc.WriteToServer(dt);
}
else if (conn is OracleConnection)
{
List<string> tmp1 = new List<string>();
List<string> tmp2 = new List<string>();
Dictionary<string, object> in_parameters = new Dictionary<string, object>();

foreach (DataColumn col in dt.Columns)
{
tmp1.Add(col.ColumnName);
tmp2.Add(':' + col.ColumnName);
in_parameters.Add("col.ColumnName", null);
}
string sqltext = "insert into " + dTableName + "(" + string.Join(",", tmp1.ToArray()) +
") values(" + string.Join(",", tmp2.ToArray()) + ")";
foreach (DataRowView dv in dt.DefaultView)
{
foreach (string key in tmp1)
{
in_parameters[key] = dv[key];
}
ExecuteNonQuery(sqltext, in_parameters, null, CommandType.Text, conn, tran);
}
}
}

111,097

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • AIGC Browser
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧