今天在用到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值,被认为是非标量类型,所以会引发了上面的错误- -#