本文整理汇总了C#中System.Collections.SortedSet.Union方法的典型用法代码示例。如果您正苦于以下问题:C# SortedSet.Union方法的具体用法?C# SortedSet.Union怎么用?C# SortedSet.Union使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类System.Collections.SortedSet
的用法示例。
在下文中一共展示了SortedSet.Union方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: ExecuteWhere
//.........这里部分代码省略.........
//ROWIDS = ROWIDS.Intersect( hs);
if(ROWIDS.Count==0) break;
else continue;
}
// end of op =
// begin op !=
if(op=="!=")
{
Index ndx = this.GetIndex(TableName,f);
Set hs = ndx.GetRowSet(val);
ROWIDS = ROWIDS.Minus( hs);
if(ROWIDS.Count==0) break;
else continue;
}
// end of op !=
// begin op >
if((op=="<")||(op==">")||(op=="<=")||(op==">="))
{
Index ndx = this.GetIndex(TableName,f);
// Metemos en un set todos los ids de fila que llevamos hasta ahora
// para luego irlas poniendo en una lista de seleccionadas
Set nSet = new SortedSet();
IComparable v = (IComparable)val;
foreach(object key in ndx.Keys)
{
IComparable o = (IComparable)key;
bool bAdd=false;
if((op==">")&&(o.CompareTo(v)>0)) bAdd=true;
else if((op=="<")&&(o.CompareTo(v)<0)) bAdd=true;
else if((op==">=")&&(o.CompareTo(v)>=0)) bAdd=true;
else if((op=="<=")&&(o.CompareTo(v)<=0)) bAdd=true;
if(bAdd)
nSet = nSet.Union( ndx.GetRowSet(key) );
}
ROWIDS = ROWIDS.Intersect( nSet );
if(ROWIDS.Count==0) break;
continue;
}
else
{
throw new Exception("Unsupported operator");
}
// end of op >
}
}
// Linear search
if(ROWIDS==null)
{
Index ndx = this.GetIndex(TableName,flds[0]);
ROWIDS = new SortedSet( ndx.GetRowSet(false) );
}
if(true)
{
int tid = (int)TableName2TID[TableName];
TableNameDef tnd = TID2Def[tid] as TableNameDef;
int valSize = (int)f.DataSize();
int Capacity = (PageSize-ContentPageDataOffset)/valSize;
ArrayList pages = f.DataFID;
if((pages.Count*Capacity)<tnd.rownum)
throw new Exception("Row num corrupted.");
ArrayList new_rowids = new ArrayList();
for(int row=0;row<tnd.rownum;row++)
{
long rowid = (long)row;
if(ROWIDS.Contains(rowid))