转:传入的表格格式数据流(TDS)远程过程调用(RPC)协议流不正确 .

近期在作淘宝客的项目,你们都知道,淘宝的商品详细描述字符长度很大,因此就致使了今天出现了一个问题数据库

 

VS的报错是这样子的  ” 传入的表格格式数据流(TDS)远程过程调用(RPC)协议流不正确“ 还说某个@desricption 过长之类的话app

直觉告诉我,某个字段过长溢出了测试

 

第一时间  :看看字段的数据类型 ,该字段类型为text,也就是无限制的长度,因此,数据库是没有问题的spa

第二 时间 :看看三层,代码生成器自动生成的代码以下这段.net

 

[csharp] view plain copy print ?
  1. db.AddInParameter(dbCommand, "@Description", DbType.AnsiString, model.Description);  
  db.AddInParameter(dbCommand, "@Description", DbType.AnsiString, model.Description);

 

那这个DbType.AnsiString到底是什么类型呢?光标点中它,按F1,打开MSDN在线帮助,问题就出如今这里,DbType.AnsiString 限制字符长度为1~8000个字符,而淘宝商品的详细介绍远远比这多!因此,我使用了另一个参数类型3d

 

[csharp] view plain copy print ?
  1. db.AddInParameter(dbCommand, "@Description", DbType.String, model.Description);  
db.AddInParameter(dbCommand, "@Description", DbType.String, model.Description);

 

保存编译,测试经过!code

 

MSDN在线文档: DbType 枚举blog

 

原创:http://blog.csdn.net/wayne20018891/article/details/7399974ip

相关文章
相关标签/搜索