从 bcp 客户端收到一个对 colid x 无效的列长度。
出现场景: 批量插入数据的时候出现这个问题。
原因分析:某个数据的长度应该是大于这个数据对应的列的定义长度。
所以一一检查到底是那个列的长度超出了。
第一种方法:
——————————2017-1-3更新——————————————
从 bcp 客户端收到一个对 colid x 无效的列长度。colid x 是多少说明是第x+1列出了问题,比如colid 1说明是第二列。那么一一排查这列的数据就可以找到问题所在。
如果数据太多的话可以直接修改数据库的字段,把字段的数据类型的长度增大就行了。比如原先varchar(50)那么可以变成varchar(100)再试一下。
——————————2017-1-3更新——————————————
网络提供了这个种方法,可以查找具体是哪个列的长度超出了。
public void GetFiledSizeTest()
{
string fileFullName = @"D:\GameLogs\2015-01-30_000000\Login.log";
//每列的最大长度
Dictionary<int, int> dicFieldLength = new Dictionary<int, int>();
//每列的最大长度所在行号
Dictionary<int, int> dicMaxFieldLenthRowNum = new Dictionary<int, int>();
for (int i = ; i < ; i++)
{
dicFieldLength.Add(i, );
dicMaxFieldLenthRowNum.Add(i, );
}
if (new FileInfo(fileFullName).Length > )
{
using (StreamReader sr = new StreamReader(fileFullName, Encoding.UTF8))
{
int rowNum = ;
while (sr.Peek() > -)
{
string strRow = sr.ReadLine();
rowNum++;
object[] objRow = strRow.Split(',');
for (int i = ; i < objRow.Length; i++)
{
var len=objRow[i].ToString().Length; if (dicFieldLength[i] < len)
{
dicFieldLength[i] = len;
dicMaxFieldLenthRowNum[i] = rowNum;
} }
}
}
}
}
——————————2017-9-4更新——————————————
注意检查这几项:1、插入的某一列的数据的长度是否大于数据库列的定义的长度?
2、数据库某一列是否不为空,而插入的数据却为空
3、当用sqlbulkcopy批量插入数据时,内存数据表DataTable的列和数据库的列是否一致。
从 bcp 客户端收到一个对 colid x 无效的列长度。的更多相关文章
- 使用BulkCopy报错 从 bcp 客户端收到一个对 colid 19 无效的列长度
====System.Data.SqlClient.SqlException: 从 bcp 客户端收到一个对 colid 19 无效的列长度. 从0开始数,数据库上表的第19列
- SqlBulkCopy 从bcp客户端收到一个对 colid 1 无效的列长度。
出现这个错误,大家都知道是因为字段长度超出了,但是这里需要注意的是,colid 1指的是数据库表的第1列,而不是C#中DataTable的第1列. 比如C#中DataTable的列顺序为{" ...
- SqlBulkCopy-从 bcp 客户端收到一个对 colid 1 无效的列长度
经过研究,问题是因为tatatable中的colid列1的数据字段长度超过了数据表中定义的字段长度. 解决方法就是将数据库该字段的长度增大问题就解决了.
- [异常记录(三)] 从 bcp 客户端收到一个对 colid 12 无效的列长度
这个问题是使用SqlBulkCopy拷贝数据,字符串长度超出数据类型长度导致的. 处理过程中对长度进行判断并截取就OK了. *注:SqlBulkCopy 这货 要求ColumnMappings 列的大 ...
- Mybatis:使用bean传值,当传入值为Null时,提示“无效的列类型”的解决办法
问题描述:在使用mybatis对数据库执行更新操作时,parameterType为某个具体的bean,而bean中传入的参数为null时,抛出异常如下:org.mybatis.spring.MyBat ...
- oracle: jdbcTypeForNull configuration property. Cause: java.sql.SQLException: 无效的列类型: 1111
https://www.cnblogs.com/mmlw/p/5808072.html org.mybatis.spring.MyBatisSystemException: nested except ...
- [转]Mybatis出现:无效的列类型: 1111 错误
原文地址:http://www.cnblogs.com/sdjnzqr/p/4304874.html 在使用Mybatis时,不同的xml配置文件,有的会提示:无效的列类型: 1111 比如这个sql ...
- [转]java.sql.SQLException: 无效的列索引
原文地址:http://blog.sina.com.cn/s/blog_6bc811e401011a17.html java.sql.SQLException: 无效的列索引 “无效的列索引”其实是个 ...
- java.sql.SQLException: 无效的列索引
java.sql.SQLException: 无效的列索引 "无效的列索引"其实是个低级的错误,原因无非几个: 1.sql串的?号数目和提供的变量数目不一致: 例如:jdbcTem ...
随机推荐
- nessus网页报错: Scans can not be saved without a policy. Please create a policy before proce
Policies添加一个用户就好了暂时还不懂什么意思以后知道再补..............
- ABAP 内表 详解
声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...
- hdu 1869 (Floyd)
http://acm.hdu.edu.cn/showproblem.php?pid=1869 六度分离 Time Limit: 5000/1000 MS (Java/Others) Memory ...
- myeclipse10.05安装aptana
安装步骤: 1.下载aptana3.2 Eclipse Plugin插件. 下载地址:http://update1.aptana.org/studio/3.2/024747/index.html 2. ...
- mysql与mysqld
mysql是客户机/服务器的结构. mysql是客户端行工具,连接mysqld服务,执行sql命令,可认为客户端sdk mysqld 启动mysql数据库服务. 脚本启动mysql服务的命令是 net ...
- linux之od命令
od [OPTION]... [FILE]... 把文件用8进制或者其他的格式显示出来.通常用于查看特殊格式文件的内容. 这个命令默认把文件的内容用八进制的形式清晰地写在标准输出上.如果是多个文件 ...
- epoll函数与参数总结学习 & errno的线程安全
select/poll被监视的文件描述符数目非常大时要O(n)效率很低:epoll与旧的 select 和 poll 系统调用完成操作所需 O(n) 不同, epoll能在O(1)时间内完成操作,所以 ...
- Android开发面试经——2.常见Android基础笔试题
标签: androidAndroid基础Android面试题Android笔试题 2015-03-12 15:04 3361人阅读 评论(3) 收藏 举报 分类: Android开发(29) 版 ...
- Jqplot使用总结之二(双Y轴)
最近需要用Jqplot做双Y轴的Chart图,首先我找到了文档上的例子并对数据做了一些调整: 1.例子展示: var s1 = [["2002-01-01", 112000], [ ...
- 虚拟机装centos 桥接方式上网[转]
http://blog.csdn.net/sunbiao0526/article/details/6804127 虚拟机选择bridge方式连接网络 首先 vi /etc/sysconfig/ne ...