EntityDataSource中的SessionParameter使用小记

简介:

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

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

2009-11-19 22-07-14

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

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

2009-11-19 22-08-06

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

2009-11-19 22-08-40

又报错:

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

2009-11-19 22-09-18

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

2009-11-19 22-10-07

又报错:

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

2009-11-19 22-08-06

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

2009-11-19 22-11-30

又报错:

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

2009-11-19 22-09-18

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

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

2009-11-19 22-15-51

通过~~

汗颜,我分析这里的原因可能是:在没有设置默认值并且Session中的此字段还未赋值的情况下,传进来了null值,被认为是非标量类型,所以会引发了上面的错误- -#


本文转自斯克迪亚博客园博客,原文链接:http://www.cnblogs.com/SkyD/archive/2009/11/19/1606462.html,如需转载请自行联系原作者

相关文章
|
8月前
|
JavaScript API
required string parameter ‘XXX‘is not present 的几种情况
required string parameter ‘XXX‘is not present 的几种情况
2105 0
Kam
|
前端开发
request.getParameter("**")获取不到值:
request.getParameter("**")获取不到值
Kam
2004 0
|
5月前
Error unprotecting the session cookie.The payload was invalid.
Error unprotecting the session cookie.The payload was invalid.
125 0
解决Missing cookie ‘JssionId‘ for method parameter of type String问题
解决Missing cookie ‘JssionId‘ for method parameter of type String问题
188 0
|
SQL
Parameter ‘id‘ not found. Available parameters are [collection, list]
Parameter ‘id‘ not found. Available parameters are [collection, list]
252 0
request.getParameter、request.getParameterValues、request.getParameterMap用法
request.getParameter、request.getParameterValues、request.getParameterMap用法
181 0
|
JSON 数据格式
Required request parameter ‘name‘ for method parameter type String is not present 报错解决方法
Required request parameter ‘name‘ for method parameter type String is not present 报错解决方法
3840 0
Parameter ‘bookID‘ not found. Available parameters are [param1, bookId]
Parameter ‘bookID‘ not found. Available parameters are [param1, bookId]
146 0
|
关系型数据库 MySQL 数据库
Your password has expired. To log in you must change it using a client that supports expired passwod
Your password has expired. To log in you must change it using a client that supports expired passwod错误解决
Your password has expired. To log in you must change it using a client that supports expired passwod
成功解决ValueError: Parameter values for parameter (n_estimators) need to be a sequence.
成功解决ValueError: Parameter values for parameter (n_estimators) need to be a sequence.
成功解决ValueError: Parameter values for parameter (n_estimators) need to be a sequence.