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

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專(zhuān)輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? ogrodbctablelayer.cpp

?? 支持各種柵格圖像和矢量圖像讀取的庫(kù)
?? CPP
字號(hào):
/****************************************************************************** * $Id: ogrodbctablelayer.cpp 10646 2007-01-18 02:38:10Z warmerdam $ * * Project:  OpenGIS Simple Features Reference Implementation * Purpose:  Implements OGRODBCTableLayer class, access to an existing table. * Author:   Frank Warmerdam, warmerdam@pobox.com * ****************************************************************************** * Copyright (c) 2003, Frank Warmerdam * * Permission is hereby granted, free of charge, to any person obtaining a * copy of this software and associated documentation files (the "Software"), * to deal in the Software without restriction, including without limitation * the rights to use, copy, modify, merge, publish, distribute, sublicense, * and/or sell copies of the Software, and to permit persons to whom the * Software is furnished to do so, subject to the following conditions: * * The above copyright notice and this permission notice shall be included * in all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER * DEALINGS IN THE SOFTWARE. ****************************************************************************/#include "cpl_conv.h"#include "ogr_odbc.h"CPL_CVSID("$Id: ogrodbctablelayer.cpp 10646 2007-01-18 02:38:10Z warmerdam $");/************************************************************************//*                          OGRODBCTableLayer()                         *//************************************************************************/OGRODBCTableLayer::OGRODBCTableLayer( OGRODBCDataSource *poDSIn ){    poDS = poDSIn;    pszQuery = NULL;    bUpdateAccess = TRUE;    bHaveSpatialExtents = FALSE;    iNextShapeId = 0;    nSRSId = -1;    poFeatureDefn = NULL;}/************************************************************************//*                          ~OGRODBCTableLayer()                          *//************************************************************************/OGRODBCTableLayer::~OGRODBCTableLayer(){    CPLFree( pszQuery );    ClearStatement();}/************************************************************************//*                             Initialize()                             *//************************************************************************/CPLErr OGRODBCTableLayer::Initialize( const char *pszTableName,                                       const char *pszGeomCol ){    CPLODBCSession *poSession = poDS->GetSession();    CPLFree( pszFIDColumn );    pszFIDColumn = NULL;/* -------------------------------------------------------------------- *//*      Do we have a simple primary key?                                *//* -------------------------------------------------------------------- */    CPLODBCStatement oGetKey( poSession );        if( oGetKey.GetPrimaryKeys( pszTableName ) && oGetKey.Fetch() )    {        pszFIDColumn = CPLStrdup(oGetKey.GetColData( 3 ));                if( oGetKey.Fetch() ) // more than one field in key!         {            CPLFree( pszFIDColumn );            pszFIDColumn = NULL;            CPLDebug( "OGR_ODBC", "Table %s has multiple primary key fields, "                      "ignoring them all.", pszTableName );        }    }/* -------------------------------------------------------------------- *//*      Have we been provided a geometry column?                        *//* -------------------------------------------------------------------- */    CPLFree( pszGeomColumn );    if( pszGeomCol == NULL )        pszGeomColumn = NULL;    else        pszGeomColumn = CPLStrdup( pszGeomCol );/* -------------------------------------------------------------------- *//*      Get the column definitions for this table.                      *//* -------------------------------------------------------------------- */    CPLODBCStatement oGetCol( poSession );    CPLErr eErr;    if( !oGetCol.GetColumns( pszTableName ) )        return CE_Failure;    eErr = BuildFeatureDefn( pszTableName, &oGetCol );    if( eErr != CE_None )        return eErr;    if( poFeatureDefn->GetFieldCount() == 0 )    {        CPLError( CE_Failure, CPLE_AppDefined,                   "No column definitions found for table '%s', layer not usable.",                   pszTableName );        return CE_Failure;    }/* -------------------------------------------------------------------- *//*      Do we have XMIN, YMIN, XMAX, YMAX extent fields?                *//* -------------------------------------------------------------------- */    if( poFeatureDefn->GetFieldIndex( "XMIN" ) != -1         && poFeatureDefn->GetFieldIndex( "XMAX" ) != -1         && poFeatureDefn->GetFieldIndex( "YMIN" ) != -1         && poFeatureDefn->GetFieldIndex( "YMAX" ) != -1 )    {        bHaveSpatialExtents = TRUE;        CPLDebug( "OGR_ODBC", "Table %s has geometry extent fields.",                  pszTableName );    }        /* -------------------------------------------------------------------- *//*      If we got a geometry column, does it exist?  Is it binary?      *//* -------------------------------------------------------------------- */    if( pszGeomColumn != NULL )    {        int iColumn = oGetCol.GetColId( pszGeomColumn );        if( iColumn < 0 )        {            CPLError( CE_Failure, CPLE_AppDefined,                       "Column %s requested for geometry, but it does not exist.",                       pszGeomColumn );            CPLFree( pszGeomColumn );            pszGeomColumn = NULL;        }        else        {            if( CPLODBCStatement::GetTypeMapping(                    oGetCol.GetColType( iColumn )) == SQL_C_BINARY )                bGeomColumnWKB = TRUE;        }    }    return CE_None;}/************************************************************************//*                           ClearStatement()                           *//************************************************************************/void OGRODBCTableLayer::ClearStatement(){    if( poStmt != NULL )    {        delete poStmt;        poStmt = NULL;    }}/************************************************************************//*                            GetStatement()                            *//************************************************************************/CPLODBCStatement *OGRODBCTableLayer::GetStatement(){    if( poStmt == NULL )        ResetStatement();    return poStmt;}/************************************************************************//*                           ResetStatement()                           *//************************************************************************/OGRErr OGRODBCTableLayer::ResetStatement(){    ClearStatement();    iNextShapeId = 0;    poStmt = new CPLODBCStatement( poDS->GetSession() );    poStmt->Append( "SELECT * FROM " );    poStmt->Append( poFeatureDefn->GetName() );    /* Append attribute query if we have it */    if( pszQuery != NULL )        poStmt->Appendf( " WHERE %s", pszQuery );    /* If we have a spatial filter, and per record extents, query on it */    if( m_poFilterGeom != NULL && bHaveSpatialExtents )    {        if( pszQuery == NULL )            poStmt->Append( " WHERE" );        else            poStmt->Append( " AND" );                poStmt->Appendf( " XMAX > %.8f AND XMIN < %.8f"                         " AND YMAX > %.8f AND YMIN < %.8f",                          m_sFilterEnvelope.MinX, m_sFilterEnvelope.MaxX,                          m_sFilterEnvelope.MinY, m_sFilterEnvelope.MaxY );    }    CPLDebug( "OGR_ODBC", "ExecuteSQL(%s)", poStmt->GetCommand() );    if( poStmt->ExecuteSQL() )        return OGRERR_NONE;    else    {        delete poStmt;        poStmt = NULL;        return OGRERR_FAILURE;    }}/************************************************************************//*                            ResetReading()                            *//************************************************************************/void OGRODBCTableLayer::ResetReading(){    ClearStatement();    OGRODBCLayer::ResetReading();}/************************************************************************//*                             GetFeature()                             *//************************************************************************/OGRFeature *OGRODBCTableLayer::GetFeature( long nFeatureId ){    if( pszFIDColumn == NULL )        return OGRODBCLayer::GetFeature( nFeatureId );    ClearStatement();    iNextShapeId = nFeatureId;    poStmt = new CPLODBCStatement( poDS->GetSession() );    poStmt->Append( "SELECT * FROM " );    poStmt->Append( poFeatureDefn->GetName() );    poStmt->Appendf( " WHERE %s = %d", pszFIDColumn, nFeatureId );    if( !poStmt->ExecuteSQL() )    {        delete poStmt;        poStmt = NULL;        return NULL;    }    return GetNextRawFeature();}/************************************************************************//*                         SetAttributeFilter()                         *//************************************************************************/OGRErr OGRODBCTableLayer::SetAttributeFilter( const char *pszQuery ){    if( (pszQuery == NULL && this->pszQuery == NULL)        || (pszQuery != NULL && this->pszQuery != NULL             && EQUAL(pszQuery,this->pszQuery)) )        return OGRERR_NONE;    CPLFree( this->pszQuery );    this->pszQuery = CPLStrdup( pszQuery );    ClearStatement();    return OGRERR_NONE;}/************************************************************************//*                           TestCapability()                           *//************************************************************************/int OGRODBCTableLayer::TestCapability( const char * pszCap ){    if( EQUAL(pszCap,OLCSequentialWrite)              || EQUAL(pszCap,OLCRandomWrite) )        return bUpdateAccess;    else if( EQUAL(pszCap,OLCCreateField) )        return bUpdateAccess;    else         return OGRODBCLayer::TestCapability( pszCap );}/************************************************************************//*                          GetFeatureCount()                           *//*                                                                      *//*      If a spatial filter is in effect, we turn control over to       *//*      the generic counter.  Otherwise we return the total count.      *//*      Eventually we should consider implementing a more efficient     *//*      way of counting features matching a spatial query.              *//************************************************************************/int OGRODBCTableLayer::GetFeatureCount( int bForce ){    return OGRODBCLayer::GetFeatureCount( bForce );}/************************************************************************//*                           GetSpatialRef()                            *//*                                                                      *//*      We override this to try and fetch the table SRID from the       *//*      geometry_columns table if the srsid is -2 (meaning we           *//*      haven't yet even looked for it).                                *//************************************************************************/OGRSpatialReference *OGRODBCTableLayer::GetSpatialRef(){#ifdef notdef    if( nSRSId == -2 )    {        PGconn          *hPGConn = poDS->GetPGConn();        PGresult        *hResult;        char            szCommand[1024];        nSRSId = -1;        poDS->SoftStartTransaction();        sprintf( szCommand,                  "SELECT srid FROM geometry_columns "                 "WHERE f_table_name = '%s'",                 poFeatureDefn->GetName() );        hResult = PQexec(hPGConn, szCommand );        if( hResult             && PQresultStatus(hResult) == PGRES_TUPLES_OK             && PQntuples(hResult) == 1 )        {            nSRSId = atoi(PQgetvalue(hResult,0,0));        }        poDS->SoftCommit();    }#endif    return OGRODBCLayer::GetSpatialRef();}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91官网在线免费观看| 亚洲视频一区二区在线观看| 亚洲欧美一区二区视频| 天天色天天爱天天射综合| 国产精品1区2区3区| 欧美日韩视频在线观看一区二区三区 | 亚洲免费观看视频| 国产在线视频精品一区| 欧美日韩免费一区二区三区| 国产精品久久99| 国产一区二区福利视频| 91麻豆精品国产91久久久久久久久| 中文字幕av一区二区三区免费看| 青青国产91久久久久久| 在线日韩国产精品| 中文字幕一区二区三区在线不卡 | 欧美日韩日日夜夜| 国产精品美女久久久久av爽李琼 | 国产欧美日韩另类一区| 日韩1区2区3区| 欧美在线看片a免费观看| 国产精品久久777777| 国产成人自拍高清视频在线免费播放| 欧美一卡二卡在线| 丝袜国产日韩另类美女| 欧美在线观看一二区| 亚洲精品第一国产综合野| 91丝袜美腿高跟国产极品老师| 中文字幕精品—区二区四季| 韩国一区二区视频| 精品理论电影在线观看| 久久av资源站| 日韩欧美一级在线播放| 久久精品72免费观看| 精品国产乱子伦一区| 激情综合五月婷婷| 久久久精品黄色| www.欧美色图| 亚洲精品中文字幕乱码三区| 91黄色免费观看| 亚洲成人黄色小说| 91精品国产一区二区人妖| 另类成人小视频在线| 国产日韩精品一区二区三区在线| 成人一区二区三区视频| 亚洲日本乱码在线观看| 欧美日韩成人在线一区| 激情欧美一区二区| 国产精品久久国产精麻豆99网站| 日本精品一级二级| 亚洲第一在线综合网站| 日韩午夜激情av| 国产成人夜色高潮福利影视| 亚洲精品一二三| 911精品国产一区二区在线| 麻豆国产精品官网| 欧美国产激情二区三区| 欧亚洲嫩模精品一区三区| 日韩高清一区在线| 久久精品无码一区二区三区| 99久久久久免费精品国产| 日韩高清一级片| 中文字幕成人在线观看| 欧美三级电影一区| 精品一区二区三区影院在线午夜| 中文在线一区二区| 欧美日韩一区不卡| 国产在线不卡一区| 亚洲综合丁香婷婷六月香| 日韩欧美国产综合在线一区二区三区 | 日韩成人午夜电影| 久久精品一区二区三区四区| 欧美性淫爽ww久久久久无| 精品一区二区在线看| 一区二区三区精品在线观看| 2020国产精品久久精品美国| 日本高清不卡视频| 国产一区二区在线视频| 亚洲精品国产视频| 久久午夜免费电影| 欧美日韩一区二区三区视频| 成人高清免费观看| 久久精品国产亚洲aⅴ| 一区二区三区在线观看动漫| xvideos.蜜桃一区二区| 欧美精品日韩一本| 97精品电影院| 国产成人在线看| 久久精品国产成人一区二区三区| 亚洲综合在线第一页| 国产精品久久久久久久蜜臀| 精品国产免费人成在线观看| 欧美精品在欧美一区二区少妇| av毛片久久久久**hd| 国产乱子伦视频一区二区三区| 丝袜美腿亚洲色图| 亚洲综合视频网| 一区二区三区四区国产精品| 中文字幕一区二区三区四区| 久久精品视频免费| 久久综合久色欧美综合狠狠| 日韩精品资源二区在线| 欧美嫩在线观看| 777奇米成人网| 欧美日韩一区二区三区免费看| 91福利国产成人精品照片| 白白色亚洲国产精品| 成人毛片视频在线观看| 国产一本一道久久香蕉| 韩国中文字幕2020精品| 国产自产v一区二区三区c| 日本网站在线观看一区二区三区| 日日夜夜精品视频天天综合网| 洋洋av久久久久久久一区| 亚洲综合自拍偷拍| 亚洲国产一区视频| 亚洲福利视频导航| 视频精品一区二区| 视频一区中文字幕| 久久成人综合网| 国产一区二区三区国产| 国产一区二区在线观看免费| 国产不卡视频在线观看| 成人免费黄色大片| 91在线观看视频| 欧美性大战久久久久久久蜜臀| 欧美午夜精品理论片a级按摩| 欧美影院一区二区三区| 日韩一区二区三区精品视频| 精品久久一二三区| 日本一区二区三区在线观看| **欧美大码日韩| 一二三四区精品视频| 蜜桃av一区二区| 国产乱码精品1区2区3区| 99久久精品国产导航| 欧美日韩成人一区| 精品国产百合女同互慰| 中文乱码免费一区二区| 亚洲自拍与偷拍| 久久91精品国产91久久小草| 成人性视频免费网站| 色噜噜偷拍精品综合在线| 欧美群妇大交群中文字幕| ww久久中文字幕| 日韩美女视频一区二区| 免费看欧美美女黄的网站| 成人永久aaa| 欧美一区二区三区白人| 中文久久乱码一区二区| 青青草原综合久久大伊人精品优势| 成人网男人的天堂| 欧美日韩亚洲综合在线| 久久久99精品久久| 亚洲国产综合视频在线观看| 国产·精品毛片| 欧美男同性恋视频网站| 国产精品精品国产色婷婷| 美腿丝袜亚洲三区| 99久久综合色| 精品国产髙清在线看国产毛片| 亚洲男人天堂av网| 国产尤物一区二区| 欧美日韩国产成人在线91| 国产精品色哟哟网站| 美女网站色91| 欧美主播一区二区三区| 中文字幕不卡在线| 激情欧美一区二区三区在线观看| 在线观看国产精品网站| 国产人妖乱国产精品人妖| 日本网站在线观看一区二区三区| 色av成人天堂桃色av| 国产午夜精品理论片a级大结局 | 国产亚洲综合av| 首页综合国产亚洲丝袜| 色综合久久久久综合99| 久久嫩草精品久久久精品一| 婷婷久久综合九色综合绿巨人| 91碰在线视频| 国产精品入口麻豆原神| 国产在线精品一区二区夜色| 欧美美女一区二区在线观看| 夜夜精品浪潮av一区二区三区| 成人黄色777网| 久久精品亚洲麻豆av一区二区| 精品一区二区免费| 欧美二区乱c少妇| 亚洲成在人线免费| 色哟哟日韩精品| 亚洲欧美日韩在线| 99精品国产热久久91蜜凸| 国产欧美一区二区三区在线老狼| 久久99九九99精品| 欧美精品色综合| 麻豆国产欧美日韩综合精品二区| 日韩一区二区三区免费看| 日韩精品久久理论片| 6080日韩午夜伦伦午夜伦| 偷窥少妇高潮呻吟av久久免费|