批量增删改数据
2015-12-26 10:09
363 查看
public bool ExecuteInsertBulkData(string tempSql, byte[] dsbyte, string sql)
{
DataSet dsRet = (DataSet)G._DeserializeObj(dsbyte);//转化成数据集
byte[] ret = null;
Database db = CreateDatabase();
SqlConnection sqlCon = null;
using (DbConnection conn = db.CreateConnection())
{
string str = sql;
sqlCon = new SqlConnection(conn.ConnectionString);
sqlCon.Open();
SqlCommand cmd = new SqlCommand(tempSql, sqlCon);//构建生成的临时表结构
int m = cmd.ExecuteNonQuery();
foreach (DataTable dt in dsRet.Tables)
{
string dtTempName = "#" + dt.TableName; //构建需要插入数据的临时表名称
SqlBulkCopy sqlBC = new SqlBulkCopy(sqlCon);//启用批量复制;
sqlBC.BulkCopyTimeout = 5000;
sqlBC.DestinationTableName = dtTempName;
sqlBC.NotifyAfter = 100;
sqlBC.WriteToServer(dt);
}
//************************开始事务操作数据*****************************//
SqlCommand command = sqlCon.CreateCommand();
SqlTransaction transaction;
transaction = sqlCon.BeginTransaction("SampleTransaction");//开始事务
command.Connection = sqlCon;
command.Transaction = transaction;
try
{
command.CommandText = sql;
command.ExecuteNonQuery();
transaction.Commit();//提交事务
return true;
}
catch (System.Exception ex)
{
G.LogErr("ExecuteInsertBulkData", ex);
transaction.Rollback();
return false;
}
finally
{
sqlCon.Close();
}
}
}
{
DataSet dsRet = (DataSet)G._DeserializeObj(dsbyte);//转化成数据集
byte[] ret = null;
Database db = CreateDatabase();
SqlConnection sqlCon = null;
using (DbConnection conn = db.CreateConnection())
{
string str = sql;
sqlCon = new SqlConnection(conn.ConnectionString);
sqlCon.Open();
SqlCommand cmd = new SqlCommand(tempSql, sqlCon);//构建生成的临时表结构
int m = cmd.ExecuteNonQuery();
foreach (DataTable dt in dsRet.Tables)
{
string dtTempName = "#" + dt.TableName; //构建需要插入数据的临时表名称
SqlBulkCopy sqlBC = new SqlBulkCopy(sqlCon);//启用批量复制;
sqlBC.BulkCopyTimeout = 5000;
sqlBC.DestinationTableName = dtTempName;
sqlBC.NotifyAfter = 100;
sqlBC.WriteToServer(dt);
}
//************************开始事务操作数据*****************************//
SqlCommand command = sqlCon.CreateCommand();
SqlTransaction transaction;
transaction = sqlCon.BeginTransaction("SampleTransaction");//开始事务
command.Connection = sqlCon;
command.Transaction = transaction;
try
{
command.CommandText = sql;
command.ExecuteNonQuery();
transaction.Commit();//提交事务
return true;
}
catch (System.Exception ex)
{
G.LogErr("ExecuteInsertBulkData", ex);
transaction.Rollback();
return false;
}
finally
{
sqlCon.Close();
}
}
}
相关文章推荐
- Android 圆形展开动画
- java中long和double类型操作的非原子性探究
- PHP中 单引号和双引号的区别
- Android黑科技之读取用户短信+修改系统短信数据库
- ural 1146. Maximum Sum
- #Objective - C - OC内存管理总结
- 不可摸数
- NSCoding 的作用
- ural 1146. Maximum Sum
- 使XML序列化器生成XML文件
- Effective C++ 条款24
- IO redirect
- cmd del命令 文件删除
- java 打包下载文件
- iOS 对初学者极右帮助的博客网址和网址
- jQuery file upload file 总结
- Android Volley完全解析
- 删除txt文件每行第一(n)个空格前内容的方法
- BTS PenTesting Lab - A3 XSS
- ural 1145. Rope in the Labyrinth