本文整理汇总了C#中IQuery.SetParameterList方法的典型用法代码示例。如果您正苦于以下问题:C# IQuery.SetParameterList方法的具体用法?C# IQuery.SetParameterList怎么用?C# IQuery.SetParameterList使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类IQuery
的用法示例。
在下文中一共展示了IQuery.SetParameterList方法的6个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: OnEvent
public void OnEvent(IQuery query)
{
switch (ctorType)
{
case CtorType.NameValsCollType:
query.SetParameterList(name, valsColl, type);
break;
case CtorType.NameValsColl:
query.SetParameterList(name, valsColl);
break;
case CtorType.NameValsObjArr:
query.SetParameterList(name, valsArr);
break;
case CtorType.NameValsObjArrType:
query.SetParameterList(name, valsArr, type);
break;
default:
throw new ShardedSessionException(
"Unknown ctor type in SetParameterListEvent: " + ctorType);
}
}
示例2: ApplyNamedParameterToQuery
/// <summary>
/// Apply the given name parameter to the given Query object.
/// </summary>
/// <param name="queryObject">The query object.</param>
/// <param name="paramName">Name of the parameter</param>
/// <param name="value">The value of the parameter</param>
/// <param name="type">The NHibernate type of the parameter (or <code>null</code> if none specified)</param>
public virtual void ApplyNamedParameterToQuery(IQuery queryObject, string paramName, object value, IType type)
{
if (value is ICollection)
{
if (type != null)
{
queryObject.SetParameterList(paramName, (ICollection)value, type);
}
else
{
queryObject.SetParameterList(paramName, (ICollection)value);
}
}
else if (value is Object[])
{
//TODO investigate support for this conversion.
if (type != null)
{
queryObject.SetParameterList(paramName, (Object[])value, type);
}
else
{
queryObject.SetParameterList(paramName, (Object[])value);
}
}
else
{
if (type != null)
{
queryObject.SetParameter(paramName, value, type);
}
else
{
queryObject.SetParameter(paramName, value);
}
}
}
示例3: SetQueryProperties
/// <summary>
/// Fill all <see cref="IQuery"/> properties.
/// </summary>
/// <param name="q">The <see cref="IQuery"/>.</param>
/// <remarks>
/// Query properties are overriden/merged.
/// </remarks>
protected void SetQueryProperties(IQuery q)
{
q.SetMaxResults(selection.MaxRows)
.SetFirstResult(selection.FirstRow)
.SetCacheable(cacheable)
.SetReadOnly(readOnly)
.SetTimeout(selection.Timeout)
.SetFlushMode(flushMode)
.SetFetchSize(selection.FetchSize);
if (!string.IsNullOrEmpty(comment))
q.SetComment(comment);
if (!string.IsNullOrEmpty(cacheRegion))
q.SetCacheRegion(cacheRegion);
if (resultTransformer != null)
q.SetResultTransformer(resultTransformer);
if (cacheMode.HasValue)
q.SetCacheMode(cacheMode.Value);
foreach (KeyValuePair<string, LockMode> mode in lockModes)
q.SetLockMode(mode.Key, mode.Value);
// Set AbstractQueryImpl property before set parameters
AbstractQueryImpl aqi = q as AbstractQueryImpl;
if (aqi != null)
aqi.SetIgnoreUknownNamedParameters(shouldIgnoredUnknownNamedParameters);
// Even if the probably that somebody use a mixed technique to set parameters
// (from POCO using SetProperties and using named parameter setters) here is a possible
// difference between IQuery and DetachedQuery behaviour.
// In IQuery we don't know who override a param value; in DetachedQuery the direct use of
// a named parameter setter override the param value set by SetProperties(POCO)
foreach (object obj in optionalUntypeParams)
q.SetProperties(obj);
// Set untyped positional parameters
foreach (KeyValuePair<int, object> pup in posUntypeParams)
q.SetParameter(pup.Key, pup.Value);
// Set untyped named parameters
foreach (KeyValuePair<string, object> nup in namedUntypeParams)
q.SetParameter(nup.Key, nup.Value);
// Set untyped named parameters list
foreach (KeyValuePair<string, ICollection> nulp in namedUntypeListParams)
q.SetParameterList(nulp.Key, nulp.Value);
// Set typed positional parameters
foreach (KeyValuePair<int, TypedValue> pp in posParams)
q.SetParameter(pp.Key, pp.Value.Value, pp.Value.Type);
// Set typed named parameters
foreach (KeyValuePair<string, TypedValue> np in namedParams)
q.SetParameter(np.Key, np.Value.Value, np.Value.Type);
// Set typed named parameters List
foreach (KeyValuePair<string, TypedValue> nlp in namedListParams)
q.SetParameterList(nlp.Key, (ICollection)nlp.Value.Value, nlp.Value.Type);
}
示例4: SetAreaTypeIdsParameter
private static void SetAreaTypeIdsParameter(IQuery q, Grouping grouping)
{
q.SetParameterList("areaTypeIds", new AreaTypeIdSplitter(grouping.AreaTypeId).Ids);
}
示例5: Apply
/// <summary>
/// Add this parameter to the <paramref name="query"/>.
/// </summary>
/// <param name="query">The query</param>
/// <remarks>
/// Is there a cleaner way to do this, without reflection or complex
/// hierarchies?
/// </remarks>
public void Apply(IQuery query)
{
if (IsFlagged(ParameterFlags.Named))
{
if (IsFlagged(ParameterFlags.List))
{
if (Type != null)
query.SetParameterList(Name, (ICollection) Value, Type);
else
query.SetParameterList(Name, (ICollection) Value);
}
else
{
if (Type != null)
query.SetParameter(Name, Value, Type);
else
query.SetParameter(Name, Value);
}
}
else if (IsFlagged(ParameterFlags.Positional))
{
if (IsFlagged(ParameterFlags.List))
{
throw new InvalidOperationException("Parameter lists can not be positional");
}
else
{
if (Type != null)
query.SetParameter(Position, Value, Type);
else
query.SetParameter(Position, Value);
}
}
}
示例6: AddParameters
/// <summary>
/// 向 IQuery 添加参数
/// </summary>
/// <param name="query"></param>
private void AddParameters(IQuery query)
{
foreach (var item in filters)
{
if (!item.NoAdd && item.PropertyType == "ARR")
query.SetParameterList(item.PlaceholderPropertyName, item.PropertyValue as object[]);
else if (!item.NoAdd)
{
//query.SetParameter(item.PlaceholderPropertyName, item.PropertyValue);
if (item.Operation == "BT")
{
string[] valarr = item.PropertyValue.ToString().Split('_');
query.SetParameter(item.PlaceholderPropertyName + "_0", ValueConverter.Convert(item.PropertyType, valarr[0]));
query.SetParameter(item.PlaceholderPropertyName + "_1", ValueConverter.Convert(item.PropertyType, valarr[1]));
}
else
{
query.SetParameter(item.PlaceholderPropertyName, ValueConverter.Convert(item.PropertyType, item.PropertyValue));
}
}
}
}