亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? ogr_gensql.cpp

?? mitab,讀取MapInfo的地圖文件
?? CPP
?? 第 1 頁 / 共 3 頁
字號:
}

/************************************************************************/
/*                           TestCapability()                           */
/************************************************************************/

int OGRGenSQLResultsLayer::TestCapability( const char *pszCap )

{
    swq_select *psSelectInfo = (swq_select *) pSelectInfo;

    if( EQUAL(pszCap,OLCFastSetNextByIndex) )
    {
        if( psSelectInfo->query_mode == SWQM_SUMMARY_RECORD 
            || psSelectInfo->query_mode == SWQM_DISTINCT_LIST 
            || panFIDIndex != NULL )
            return TRUE;
        else 
            return poSrcLayer->TestCapability( pszCap );
    }

    if( psSelectInfo->query_mode == SWQM_RECORDSET
        && (EQUAL(pszCap,OLCFastFeatureCount) 
            || EQUAL(pszCap,OLCRandomRead) 
            || EQUAL(pszCap,OLCFastGetExtent)) )
        return poSrcLayer->TestCapability( pszCap );

    else if( psSelectInfo->query_mode != SWQM_RECORDSET )
    {
        if( EQUAL(pszCap,OLCFastFeatureCount) )
            return TRUE;
    }

    return FALSE;
}

/************************************************************************/
/*                           PrepareSummary()                           */
/************************************************************************/

int OGRGenSQLResultsLayer::PrepareSummary()

{
    swq_select *psSelectInfo = (swq_select *) pSelectInfo;

    if( poSummaryFeature != NULL )
        return TRUE;

    poSummaryFeature = new OGRFeature( poDefn );
    poSummaryFeature->SetFID( 0 );

/* -------------------------------------------------------------------- */
/*      Ensure our query parameters are in place on the source          */
/*      layer.  And initialize reading.                                 */
/* -------------------------------------------------------------------- */
    poSrcLayer->SetAttributeFilter( psSelectInfo->whole_where_clause );
    
    poSrcLayer->SetSpatialFilter( m_poFilterGeom );
        
    poSrcLayer->ResetReading();

/* -------------------------------------------------------------------- */
/*      We treat COUNT(*) (or COUNT of anything without distinct) as    */
/*      a special case, and fill with GetFeatureCount().                */
/* -------------------------------------------------------------------- */

    if( psSelectInfo->result_columns == 1 
        && psSelectInfo->column_defs[0].col_func == SWQCF_COUNT
        && !psSelectInfo->column_defs[0].distinct_flag )
    {
        poSummaryFeature->SetField( 0, poSrcLayer->GetFeatureCount( TRUE ) );
        return TRUE;
    }

/* -------------------------------------------------------------------- */
/*      Otherwise, process all source feature through the summary       */
/*      building facilities of SWQ.                                     */
/* -------------------------------------------------------------------- */
    const char *pszError;
    OGRFeature *poSrcFeature;

    while( (poSrcFeature = poSrcLayer->GetNextFeature()) != NULL )
    {
        for( int iField = 0; iField < psSelectInfo->result_columns; iField++ )
        {
            swq_col_def *psColDef = psSelectInfo->column_defs + iField;

            pszError = swq_select_summarize( psSelectInfo, iField, 
                                          poSrcFeature->GetFieldAsString( 
                                              psColDef->field_index ) );
            
            if( pszError != NULL )
            {
                delete poSummaryFeature;
                poSummaryFeature = NULL;

                CPLError( CE_Failure, CPLE_AppDefined, "%s", pszError );
                return FALSE;
            }
        }

        delete poSrcFeature;
    }

    pszError = swq_select_finish_summarize( psSelectInfo );
    if( pszError != NULL )
    {
        delete poSummaryFeature;
        poSummaryFeature = NULL;
        
        CPLError( CE_Failure, CPLE_AppDefined, "%s", pszError );
        return FALSE;
    }

/* -------------------------------------------------------------------- */
/*      If we have run out of features on the source layer, clear       */
/*      away the filters we have installed till a next run through      */
/*      the features.                                                   */
/* -------------------------------------------------------------------- */
    if( poSrcFeature == NULL )
        ClearFilters();

/* -------------------------------------------------------------------- */
/*      Now apply the values to the summary feature.  If we are in      */
/*      DISTINCT_LIST mode we don't do this step.                       */
/* -------------------------------------------------------------------- */
    if( psSelectInfo->query_mode == SWQM_SUMMARY_RECORD 
        && psSelectInfo->column_summary != NULL )
    {
        for( int iField = 0; iField < psSelectInfo->result_columns; iField++ )
        {
            swq_col_def *psColDef = psSelectInfo->column_defs + iField;
            swq_summary *psSummary = psSelectInfo->column_summary + iField;

            if( psColDef->col_func == SWQCF_AVG )
                poSummaryFeature->SetField( iField, 
                                        psSummary->sum / psSummary->count );
            else if( psColDef->col_func == SWQCF_MIN )
                poSummaryFeature->SetField( iField, psSummary->min );
            else if( psColDef->col_func == SWQCF_MAX )
                poSummaryFeature->SetField( iField, psSummary->max );
            else if( psColDef->col_func == SWQCF_COUNT )
                poSummaryFeature->SetField( iField, psSummary->count );
            else if( psColDef->col_func == SWQCF_SUM )
                poSummaryFeature->SetField( iField, psSummary->sum );
        }
    }

    return TRUE;
}

/************************************************************************/
/*                          TranslateFeature()                          */
/************************************************************************/

OGRFeature *OGRGenSQLResultsLayer::TranslateFeature( OGRFeature *poSrcFeat )

{
    swq_select *psSelectInfo = (swq_select *) pSelectInfo;
    OGRFeature *poDstFeat;

    if( poSrcFeat == NULL )
        return NULL;

    m_nFeaturesRead++;

/* -------------------------------------------------------------------- */
/*      Create destination feature.                                     */
/* -------------------------------------------------------------------- */
    poDstFeat = new OGRFeature( poDefn );

    poDstFeat->SetFID( poSrcFeat->GetFID() );

    poDstFeat->SetGeometry( poSrcFeat->GetGeometryRef() );
    
/* -------------------------------------------------------------------- */
/*      Copy fields from primary record to the destination feature.     */
/* -------------------------------------------------------------------- */
    for( int iField = 0; iField < psSelectInfo->result_columns; iField++ )
    {
        swq_col_def *psColDef = psSelectInfo->column_defs + iField;

        if ( psColDef->field_index >= iFIDFieldIndex &&
            psColDef->field_index < iFIDFieldIndex + SPECIAL_FIELD_COUNT )
        {
            switch (SpecialFieldTypes[psColDef->field_index - iFIDFieldIndex])
            {
              case SWQ_INTEGER:
                poDstFeat->SetField( iField, poSrcFeat->GetFieldAsInteger(psColDef->field_index) );
                break;
              default:
                poDstFeat->SetField( iField, poSrcFeat->GetFieldAsString(psColDef->field_index) );
            }
        }
        else if( psColDef->table_index == 0 )
            poDstFeat->SetField( iField,
                         poSrcFeat->GetRawFieldRef( psColDef->field_index ) );
    }

/* -------------------------------------------------------------------- */
/*      Copy values from any joined tables.                             */
/* -------------------------------------------------------------------- */
    int iJoin;

    for( iJoin = 0; iJoin < psSelectInfo->join_count; iJoin++ )
    {
        char szFilter[512];

        swq_join_def *psJoinInfo = psSelectInfo->join_defs + iJoin;
        OGRLayer *poJoinLayer = papoTableLayers[psJoinInfo->secondary_table];
        
        // if source key is null, we can't do join.
        if( !poSrcFeat->IsFieldSet( psJoinInfo->primary_field ) )
            continue;

        // Prepare attribute query to express fetching on the joined variable
        sprintf( szFilter, "%s = ", 
                 poJoinLayer->GetLayerDefn()->GetFieldDefn( 
                     psJoinInfo->secondary_field )->GetNameRef() );

        OGRField *psSrcField = 
            poSrcFeat->GetRawFieldRef(psJoinInfo->primary_field);

        switch( poSrcLayer->GetLayerDefn()->GetFieldDefn( 
                    psJoinInfo->primary_field )->GetType() )
        {
          case OFTInteger:
            sprintf( szFilter+strlen(szFilter), "%d", psSrcField->Integer );
            break;

          case OFTReal:
            sprintf( szFilter+strlen(szFilter), "%.16g", psSrcField->Real );
            break;

          case OFTString:
            // the string really ought to be escaped. 
            sprintf( szFilter+strlen(szFilter), "\"%s\"", 
                     psSrcField->String );
            break;

          default:
            CPLAssert( FALSE );
            continue;
        }

        poJoinLayer->ResetReading();
        if( poJoinLayer->SetAttributeFilter( szFilter ) != OGRERR_NONE )
            continue;

        // Fetch first joined feature.
        OGRFeature *poJoinFeature;

        poJoinFeature = poJoinLayer->GetNextFeature();

        if( poJoinFeature == NULL )
            continue;

        // Copy over selected field values. 
        for( int iField = 0; iField < psSelectInfo->result_columns; iField++ )
        {
            swq_col_def *psColDef = psSelectInfo->column_defs + iField;
            
            if( psColDef->table_index == psJoinInfo->secondary_table )
                poDstFeat->SetField( iField,
                                     poJoinFeature->GetRawFieldRef( 
                                         psColDef->field_index ) );
        }

        delete poJoinFeature;
    }

    return poDstFeat;
}

/************************************************************************/
/*                           GetNextFeature()                           */
/************************************************************************/

OGRFeature *OGRGenSQLResultsLayer::GetNextFeature()

{
    swq_select *psSelectInfo = (swq_select *) pSelectInfo;

/* -------------------------------------------------------------------- */
/*      Handle summary sets.                                            */
/* -------------------------------------------------------------------- */
    if( psSelectInfo->query_mode == SWQM_SUMMARY_RECORD 
        || psSelectInfo->query_mode == SWQM_DISTINCT_LIST )
        return GetFeature( nNextIndexFID++ );

/* -------------------------------------------------------------------- */
/*      Handle ordered sets.                                            */
/* -------------------------------------------------------------------- */
    while( TRUE )
    {
        OGRFeature *poFeature;

        if( panFIDIndex != NULL )
            poFeature =  GetFeature( nNextIndexFID++ );
        else
        {
            OGRFeature *poSrcFeat = poSrcLayer->GetNextFeature();

            if( poSrcFeat == NULL )
                return NULL;
            
            poFeature = TranslateFeature( poSrcFeat );
            delete poSrcFeat;
        }

        if( poFeature == NULL )
            return NULL;

        if( m_poAttrQuery == NULL
            || m_poAttrQuery->Evaluate( poFeature ) )
            return poFeature;

        delete poFeature;
    }

    return NULL;
}

/************************************************************************/
/*                             GetFeature()                             */
/************************************************************************/

OGRFeature *OGRGenSQLResultsLayer::GetFeature( long nFID )

{
    swq_select *psSelectInfo = (swq_select *) pSelectInfo;

/* -------------------------------------------------------------------- */
/*      Handle request for summary record.                              */
/* -------------------------------------------------------------------- */
    if( psSelectInfo->query_mode == SWQM_SUMMARY_RECORD )
    {
        if( !PrepareSummary() || nFID != 0 || poSummaryFeature == NULL )
            return NULL;
        else
            return poSummaryFeature->Clone();
    }

/* -------------------------------------------------------------------- */
/*      Handle request for distinct list record.                        */
/* -------------------------------------------------------------------- */
    if( psSelectInfo->query_mode == SWQM_DISTINCT_LIST )
    {
        if( !PrepareSummary() )
            return NULL;

        swq_summary *psSummary = psSelectInfo->column_summary + 0;

        if( psSummary == NULL )

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本一不卡视频| 91精品国产高清一区二区三区| 精品系列免费在线观看| 日韩影院免费视频| 久久久久久久久久久久久夜| 国产在线视频不卡二| 天天色图综合网| 亚洲成在人线在线播放| 亚洲第一会所有码转帖| 亚洲成人免费视频| 天堂久久一区二区三区| 天堂va蜜桃一区二区三区| 日韩国产一区二| 久久成人综合网| 国产黄色精品网站| www.久久久久久久久| 国产精品传媒视频| 亚洲国产一区二区三区青草影视| 久久aⅴ国产欧美74aaa| 欧美精品一卡两卡| 欧美日韩亚洲国产综合| 成人av影视在线观看| 亚洲国产日韩一级| 韩国av一区二区三区| 国产伦理精品不卡| 国内精品免费**视频| 精品一区二区三区不卡| 成人永久免费视频| 北条麻妃国产九九精品视频| 不卡高清视频专区| 亚洲国产精品久久不卡毛片| 一区二区中文视频| 欧美日韩成人高清| 亚洲激情中文1区| 中文字幕乱码一区二区免费| 成人教育av在线| 国产综合一区二区| 日韩**一区毛片| 欧美三级电影一区| 日韩精品一区二区三区在线| 欧美一区二区三区免费| 欧美日韩国产美女| 欧美在线观看一二区| 色天天综合色天天久久| 国产精品视频看| 日韩视频在线一区二区| 欧美电视剧在线看免费| 成人av在线影院| 亚洲美女淫视频| 成人一区二区在线观看| 欧美日韩国产不卡| 成人永久aaa| 欧美国产视频在线| 中文字幕字幕中文在线中不卡视频| 久久精品99国产精品| 成人app软件下载大全免费| 欧美二区在线观看| 国产69精品久久99不卡| 欧美色网一区二区| 亚洲狼人国产精品| 日本一区二区三区四区在线视频| 国产精品久久久久久久裸模| 亚洲国产va精品久久久不卡综合| 亚洲欧洲国产专区| 91美女片黄在线| 一区二区三区国产| 精品系列免费在线观看| 欧美精选午夜久久久乱码6080| 亚洲一区二区三区自拍| 日韩精品中文字幕在线不卡尤物| 欧美日韩国产在线观看| 欧美tickle裸体挠脚心vk| 午夜视频在线观看一区二区三区| 99在线视频精品| 亚洲成av人综合在线观看| 亚洲欧美日韩国产一区二区三区| 成人黄色av电影| 亚洲欧美日韩中文播放 | 国产精品区一区二区三| 亚洲成av人片观看| 国产精品一二二区| 欧美视频一区在线观看| 国产乱子伦一区二区三区国色天香| 色中色一区二区| 国产福利精品导航| 色视频一区二区| 奇米精品一区二区三区在线观看一| 亚洲综合在线视频| 久久一区二区视频| 久久五月婷婷丁香社区| 成人av网站在线观看免费| 91精品国产美女浴室洗澡无遮挡| 成人av网站免费观看| 1024精品合集| 久久久噜噜噜久久人人看| 精品综合免费视频观看| 同产精品九九九| 亚洲欧美色图小说| 日韩av电影天堂| 午夜国产不卡在线观看视频| 久久99国产精品久久99| 欧美色电影在线| 国产麻豆成人传媒免费观看| 亚洲同性gay激情无套| 久久精品水蜜桃av综合天堂| 国产成人免费在线观看| 国产日韩v精品一区二区| 日本不卡一二三| 日韩欧美国产一区二区在线播放| 麻豆精品一区二区| 日韩精品一区二区三区视频| 激情成人午夜视频| 精品日韩99亚洲| 日韩高清不卡在线| 精品美女被调教视频大全网站| 国产精品亚洲人在线观看| 中文字幕巨乱亚洲| 制服丝袜日韩国产| 成人国产电影网| 美腿丝袜一区二区三区| 亚洲欧洲无码一区二区三区| 在线播放国产精品二区一二区四区| 青青草97国产精品免费观看 | 日韩制服丝袜先锋影音| 久久久精品影视| 欧美午夜一区二区三区免费大片| 国产自产视频一区二区三区| 亚洲影院理伦片| 欧美日韩一本到| hitomi一区二区三区精品| 一区二区三区精品在线| 国产亚洲欧美一级| 欧美嫩在线观看| 在线一区二区观看| 国产一区999| 一区二区三区在线视频观看58 | 国产精品久久国产精麻豆99网站| 欧美精品久久99久久在免费线| 成人av在线资源| 久久国产婷婷国产香蕉| 一级做a爱片久久| 国产精品久久久久久久久免费樱桃| 日韩欧美成人一区| 日韩美女在线视频 | 日日夜夜精品视频天天综合网| 亚洲视频一区二区在线观看| 国产午夜亚洲精品理论片色戒| 欧美精品一卡两卡| 色偷偷一区二区三区| 成人久久久精品乱码一区二区三区| 日本大胆欧美人术艺术动态| 亚洲第四色夜色| 日日摸夜夜添夜夜添精品视频| 一级日本不卡的影视| 亚洲一卡二卡三卡四卡五卡| 亚洲激情综合网| 亚洲国产精品久久人人爱| 亚洲一二三区不卡| 午夜日韩在线观看| 蜜桃av一区二区在线观看| 日本成人在线不卡视频| 免费av网站大全久久| 久久se精品一区精品二区| 美国三级日本三级久久99 | 三级欧美在线一区| 日本不卡一区二区三区高清视频| 午夜精品久久久久久久久久| 日本在线不卡视频一二三区| 日本成人中文字幕在线视频| 精品系列免费在线观看| zzijzzij亚洲日本少妇熟睡| 色婷婷综合激情| 欧美嫩在线观看| 精品久久久久久久久久久久包黑料| 337p粉嫩大胆色噜噜噜噜亚洲| 久久伊人中文字幕| 久久九九全国免费| 日韩一区中文字幕| 亚洲激情校园春色| 亚洲一级二级三级| 日本美女一区二区三区| 国产麻豆成人精品| 欧美图片一区二区三区| 日韩视频永久免费| 午夜不卡av在线| 精品一区二区在线播放| 91免费版在线| 日韩久久免费av| 国产精品福利电影一区二区三区四区| 亚洲一区二区三区四区的| 日本不卡视频在线观看| 99久久精品国产毛片| 欧美一卡二卡在线| 国产精品久久久久久久久快鸭| 亚洲国产精品久久人人爱| 午夜久久久久久久久| 国产精品自拍三区| 欧美日韩一区二区三区四区| 国产日韩欧美高清| 美女视频一区二区三区|