Fields属性查询

/// <summary>
        /// 根据Fields进行属性查询
        /// </summary>
        /// <param name="FeaClass">要素集</param>
        /// <param name="QueryKeyWords">查询关键字</param>
        /// <returns></returns>
        public List<IFeature> Query(IFeatureClass FeaClass, string QueryKeyWords)
        {
            ////TODO Field查询语句
            List<IFeature> lstFea = null;
            try
            {
                if (FeaClass == null)
                {
                    return null;
                }

                IField pTmpField = null;
                string sWhereExpress = "";

                //// 遍历字段 获得查询条件
                for (int i = 0; i < FeaClass.Fields.FieldCount; i++)
                {
                    pTmpField = FeaClass.Fields.get_Field(i);

                    if (pTmpField.Type != esriFieldType.esriFieldTypeString)
                    {
                        continue;
                    }

                    sWhereExpress += string.Format("{0} LIKE '%{1}%' OR ", pTmpField.Name, QueryKeyWords);
                }

                sWhereExpress = sWhereExpress.Substring(0, sWhereExpress.LastIndexOf("OR") - 1);
                IQueryFilter pQueryFilter = new QueryFilterClass();
                pQueryFilter.WhereClause = sWhereExpress;
                IFeatureCursor pFeaCursor = FeaClass.Search(pQueryFilter, false);
                IFeature pFea = pFeaCursor.NextFeature();

                while (pFea != null)
                {
                    lstFea.Add(pFea);
                    pFea = pFeaCursor.NextFeature();
                }
            }
            catch (Exception ex)
            {
                return null;
            }
            return lstFea;

        }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值