您的位置:首页 > 其它

EntityDataSource中的SessionParameter使用小记

2009-11-19 22:58 288 查看

今天在用到SessionParameter的时候真是抓狂了,改了半天都报错,网上搜也没有找到类似遭遇的记录,费了好半天才鼓捣出来~~在此记录一下过程。

首先插入一个EntityDataSource,并指派一个SessionParameter:



这里没指定数据类型,而EntityDataSource必须要求指定数据类型,所以就报错:

异常详细信息: System.InvalidOperationException: 对于 EntityDataSource,必须为每个 Parameter 指定 Type 或 DbType (但不能同时指定)。




OK,那就指定出类型呗,这里是Guid类型:



又报错:

异常详细信息: System.ArgumentOutOfRangeException: 指定的参数类型“System.Object”无效。仅支持标量类型,例如 System.Int32、System.Decimal、System.DateTime 和 System.Guid。
参数名: parameter





不明所以~不过猜测是因为Session里的值传过来就是Object类型,所以类型不匹配?于是就改为Object类型:



又报错:

异常详细信息: System.InvalidOperationException: 对于 EntityDataSource,必须为每个 Parameter 指定 Type 或 DbType (但不能同时指定)。




这就更一头雾水了,分明指定了DbType,还出这个提示也太扯了吧!算了,试试指定为Type吧,但Type里没有Guid类型,只好还是指定为Object:



又报错:

异常详细信息: System.ArgumentOutOfRangeException: 指定的参数类型“System.Object”无效。仅支持标量类型,例如 System.Int32、System.Decimal、System.DateTime 和 System.Guid。
参数名: parameter





我这时已经快疯了!这都什么狗屁错误提示啊!!

后来全无把握地又做了一个尝试,加设Guid的默认值00000000-0000-0000-0000-000000000000:



通过~~

汗颜,我分析这里的原因可能是:在没有设置默认值并且Session中的此字段还未赋值的情况下,传进来了null值,被认为是非标量类型,所以会引发了上面的错误- -#
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: