C# 平时碰见的问题【1】
1. SqlBulkCopy
可以利用这个类实现快速大批量新增数据的效果, 但在使用过程中发现了一个问题: 无法将数据源中的DateTime类型转换成数据库中的int类型
看起来就是数据列不对应导致的, 不过一开始也不确定,后面试验确定 SqlBulkCopy 自建的DataTable数据源writeToServer在未添加列与列的映射(ColumnMappings)时候即使列名一致 也并不是按列名写入数据的,而是按列的索引进行添加的.
故解决方法有二个:
(1) 在自建的数据源DataTable中补充前面的列 (若列处于需要添加的字段后面 则不用);
(2) SqlBulkCopy 列映射集合中添加 sqlBulkCopy.ColumnMappings.Add(sourceColumn, destinationColumn); 将每列与目标数据库中的表关联;
代码如下:
public bool BulkAddData(string recordsString)
{
string[] records = recordsString.Split('$');
bool boolIsSuccess = false;
DataTable dtTemp = new DataTable();
dtTemp.Columns.Add(new DataColumn("ID", typeof(int))); //(1)ID在目标表中是自增列,并且是第一列
dtTemp.Columns.Add(new DataColumn("ScanUserID", typeof(int)));
dtTemp.Columns.Add(new DataColumn("ScanDate", typeof(DateTime)));
dtTemp.Columns.Add(new DataColumn("PO", typeof(string)));
dtTemp.Columns.Add(new DataColumn("SerialNumber", typeof(string)));
dtTemp.Columns.Add(new DataColumn("Container", typeof(string)));
dtTemp.Columns.Add(new DataColumn("ModelName", typeof(string)));
dtTemp.Columns.Add(new DataColumn("ModelID", typeof(int))); foreach (string record in records)
{
DataRow dr = dtTemp.NewRow();
string[] strModel = record.Split(',');
if (strModel.Length == )
{
// ID是自增列,不用赋值
dr["ScanUserID"] = int.Parse(strModel[]);
dr["ScanDate"] = DateTime.Parse(strModel[]);
dr["PO"] = strModel[];
dr["SerialNumber"] = strModel[];
dr["Container"] = strModel[];
dr["ModelName"] = strModel[];
dr["ModelID"] = int.Parse(strModel[]);
}
dtTemp.Rows.Add(dr);
}
string strConnectionString = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString.ToString();
using (SqlConnection conn = new SqlConnection(strConnectionString))
{
conn.Open();
SqlTransaction tran = conn.BeginTransaction();
SqlBulkCopy sqlBulkCopy = new SqlBulkCopy(conn, SqlBulkCopyOptions.Default, tran);
sqlBulkCopy.DestinationTableName = "T_DeliveryRecord";
sqlBulkCopy.BatchSize = dtTemp.Rows.Count;
//(2) SqlBulkCopy 的表映射默认是按索引来和目标表对应的, 可通过以下方法强制对应
//sqlBulkCopy.ColumnMappings.Add("ScanUserID", "ScanUserID");
//sqlBulkCopy.ColumnMappings.Add("ScanDate", "ScanDate");
//sqlBulkCopy.ColumnMappings.Add("PO", "PO");
//sqlBulkCopy.ColumnMappings.Add("SerialNumber", "SerialNumber");
//sqlBulkCopy.ColumnMappings.Add("Container", "Container");
//sqlBulkCopy.ColumnMappings.Add("ModelName", "ModelName");
//sqlBulkCopy.ColumnMappings.Add("ModelID", "ModelID"); try
{
sqlBulkCopy.WriteToServer(dtTemp);
tran.Commit();
boolIsSuccess = true;
}
catch
{
tran.Rollback();
boolIsSuccess = false;
}
finally
{
sqlBulkCopy.Close();
}
} return boolIsSuccess;
}
ID是我的主键自增的列,位于表的第一位, 所以dtTemp中没有ID列的时候 ScanDate的数据 将插入数据库中的ScanUserID这个int类型的字段中出现上面提到的类型错误; 也就是列的不对应;
所以用方法(1) 解决本问题时, 临时数据表的字段名及顺序需要与目标表一致, 有默认值或者自增的字段不需要赋值; 当然这种情况的列只是作为占位,字段名不用对应也可以:如上面的dtTemp.Columns.Add(new DataColumn("ID", typeof(int))) 改成 dtTemp.Columns.Add(new DataColumn("AA", typeof(int))) 一样也是可以的 );
attention: 注意如果给自增列赋值且SqlBulkCopyOptions.KeepIdentity 将导致目标表该自增列的自增失效;
C# 平时碰见的问题【1】的更多相关文章
- C# 平时碰见的问题【6】
EF Code First 设置复合主键的方法 除了单纯多对多的关系表外, 我们可能在关系表上加其他的属性: 比如[订单行] 对应的[订单]和[商品]就需要多一个数量字段 而又不想在这个[订单行]表上 ...
- C# 平时碰见的问题【5】
vs按F5启动调试,项目不会编译的解决办法 工具 -> 选项 -> 项目和解决方案 -> 运行时, 当项目过期(下拉框) -> 不要选[从不生成] 附英文版的:
- C# 平时碰见的问题【4】
1. 模糊查询 like的参数化写法 string keyword="value"; // 要模糊匹配的值 错误示范: sql: string strSql=" ...
- C# 平时碰见的问题【3】
今天发现一个问题纳闷了半个小时, 需求是处理project文件里边的数据内容,其中需要判断任务名称不存在重复; 在测试的时候弄了两行一样的任务,如预想: 任务[xxx]重复 然后删掉重复的任务行,继续 ...
- C# 平时碰见的问题【2】
问题1 修改命名空间后 .ashx 类型创建失败 [情景] 在调整前后台项目结构的时候,修改了默认命名空间(XXX.Admin 修改成XXX.Web),结果调试的时候发现XXX.Admin.Ajax. ...
- Android使用静默安装时碰见的问题
升级时碰见的异常 private void installPackage(String appName,final File apk) { if (!apk.exists()) { setHasNew ...
- 使用karma测试平时写的小demo(arguments为例)
有人说前端自动化测试非常困难,我觉得确实如此.在项目中,我个人也不放心写的测试,还是要手动测试.但是我们平时写demo学习时,完全可以使用自动化测试. 传统demo 1,新建一个html 2,写入js ...
- CSS3动画几个平时没注意的属性
一.timing-function: steps() 一开始在使用CSS3的时候并没有太注意这个timing-function,只是注意到自定义贝塞尔曲线. 1)一个项目中的实例 先来看看左边加了st ...
- 这些HTML、CSS知识点,面试和平时开发都需要 No1-No4
系列知识点汇总 这些HTML.CSS知识点,面试和平时开发都需要 No1-No4(知识点:HTML.CSS.盒子模型.内容布局) 这些HTML.CSS知识点,面试和平时开发都需要 No5-No7(知识 ...
随机推荐
- Spark是一种分布式的计算方案
Spark的安装基于HDFS,所以我们要设置hadoop的配置文件,所以spark的存储不是其主要的功能点,而spark作为分布式生态中的角色是一种计算模式(其他 的计算 模式,比如MR,Storm, ...
- 深度解析EM菌
现在,在各大水族论坛里知道什么是EM菌的人不多,能正确说出EM菌的原理.成分和用途的人更是凤毛麟角,很多人对EM菌是否适用于水族箱存有疑虑,他们认为EM菌里大部分都是厌氧菌,因此不适合在水族箱这种好氧 ...
- The specified system/compiler is not supported
之前安装了QT的4.5.3版本,现需要用到phonon库,因此卸载后想重新安装4.7版本,但当使用./configure编译时出现The specified system/compiler is no ...
- SparkSQL使用之Thrift JDBC server
Thrift JDBC Server描述 Thrift JDBC Server使用的是HIVE0.12的HiveServer2实现.能够使用Spark或者hive0.12版本的beeline脚本与JD ...
- TestCase--网站注册模块
对于web测试,注册模块是必测的一个点,所以今天就来总结一下注册模块的测试用例 参考京东的注册页面 测试用例设计如下: 一.功能测试 1. 单击“免费注册”,页面是否正常跳转 2. 直接访问注册页 ...
- 反向生成hbm.xml
选择数据库透视图 打开数据连接 打开刚刚创建的连接,然后打开用户名下的表 这个就是she用户下的表,我们选中要反向生成的表,可以多选,然后点击右键 点击Hibernate Reverse Engine ...
- ctags 文章
http://blog.csdn.net/wuziqi4/article/details/1709722
- php中若干模块的安装
1.php的mysql扩展pdo_mysql(在php源码所在目录) 1.1 进入 PHP 的软件包 pdo 扩展目录中 cd /usr/local/services/php-5.6.5/ext/ ...
- 智能指针(一):STL auto_ptr实现原理
智能指针实际上是一个类(class),里面封装了一个指针.它的用处是啥呢? 指针与内存 说到指针自然涉及到内存.我们如果是在堆栈(stack)中分配了内存,用完后由系统去负责释放.如果是自定义类型,就 ...
- APUE第五章:标准IO库
5.2流和file对象 #include <wchar.h> int fwide(FILE *fp, int mode); Returns: positive if stream is w ...