源例子:
cmd.Parameters.Add("@title", SqlDbType.NVarChar, 255);
cmd.Parameters.Add("@body", SqlDbType.NText);
现在要把ntext改为nvarchar(MAX)
------解决方案--------------------------------------------------------
md.Parameters.Add("@title", SqlDbType.NVarChar, 数据库里的字段长度);
------解决方案--------------------------------------------------------
body如果太长的话估计你用NVarchar存不进去。
------解决方案--------------------------------------------------------
byte[] data = ...;
cmd.Parameters.Add("@data", SqlDbType.VarBinary, data.Length);
------解决方案--------------------------------------------------------
up
cmd.Parameters.Add("@data", SqlDbType.NVarChar,255);
------解决方案--------------------------------------------------------
在存储过程里定义参数的时候用 @body nvarchar(Max) ,
必须和表字段里的类型值 保持一致,选择 varchar(MAX) 。
cmd.Parameters.Add("@body", SqlDbType.NVarChar);
------解决方案--------------------------------------------------------
好像是4000,
varchar是8000,
ntext不限长度。
------解决方案--------------------------------------------------------
在存储过程里定义参数的时候用 @body nvarchar(Max) ,
必须和表字段里的类型值 保持一致,选择 varchar(MAX) 。
正解
cmd.Parameters.Add("@body", SqlDbType.NVarChar); [color=#FF0000][/color]
------解决方案--------------------------------------------------------
cmd.Parameters.Add("@body", SqlDbType.NVarChar);
不写长度
或者写数据库支持的max长度 应该是8000