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

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

?? ogrsqlitetablelayer.cpp

?? 支持各種柵格圖像和矢量圖像讀取的庫
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
/****************************************************************************** * $Id: ogrsqlitetablelayer.cpp 10646 2007-01-18 02:38:10Z warmerdam $ * * Project:  OpenGIS Simple Features Reference Implementation * Purpose:  Implements OGRSQLiteTableLayer class, access to an existing table. * Author:   Frank Warmerdam, warmerdam@pobox.com * ****************************************************************************** * Copyright (c) 2004, 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 "cpl_string.h"#include "ogr_sqlite.h"#include <string>CPL_CVSID("$Id: ogrsqlitetablelayer.cpp 10646 2007-01-18 02:38:10Z warmerdam $");/************************************************************************//*                        OGRSQLiteTableLayer()                         *//************************************************************************/OGRSQLiteTableLayer::OGRSQLiteTableLayer( OGRSQLiteDataSource *poDSIn ){    poDS = poDSIn;    pszQuery = NULL;    bUpdateAccess = TRUE;    iNextShapeId = 0;    nSRSId = -1;    poFeatureDefn = NULL;}/************************************************************************//*                        ~OGRSQLiteTableLayer()                        *//************************************************************************/OGRSQLiteTableLayer::~OGRSQLiteTableLayer(){    CPLFree( pszQuery );    ClearStatement();}/************************************************************************//*                             Initialize()                             *//************************************************************************/CPLErr OGRSQLiteTableLayer::Initialize( const char *pszTableName,                                         const char *pszGeomCol ){    sqlite3 *hDB = poDS->GetDB();    CPLFree( pszGeomColumn );    if( pszGeomCol == NULL )        pszGeomColumn = NULL;    else        pszGeomColumn = CPLStrdup( pszGeomCol );    CPLFree( pszFIDColumn );    pszFIDColumn = NULL;/* -------------------------------------------------------------------- *//*      Get the column definitions for this table.                      *//* -------------------------------------------------------------------- */    CPLErr eErr;    sqlite3_stmt *hColStmt = NULL;    const char *pszSQL = CPLSPrintf( "SELECT _rowid_, * FROM '%s' LIMIT 1",                                     pszTableName );    if( sqlite3_prepare( hDB, pszSQL, strlen(pszSQL), &hColStmt, NULL )        != SQLITE_OK )    {        CPLError( CE_Failure, CPLE_AppDefined,                   "Unable to query table %s for column definitions.",                  pszTableName );                return CE_Failure;    }        sqlite3_step( hColStmt );/* -------------------------------------------------------------------- *//*      What should we use as FID?  If there is a primary key           *//*      integer field, then this will be used as the _rowid_, and we    *//*      will pick up the real column name here.  Otherwise, we will     *//*      just use fid.                                                   *//*                                                                      *//*      Note that the select _rowid_ will return the real column        *//*      name if the rowid corresponds to another primary key            *//*      column.                                                         *//* -------------------------------------------------------------------- */    pszFIDColumn = CPLStrdup(sqlite3_column_name( hColStmt, 0 ));/* -------------------------------------------------------------------- *//*      Collect the rest of the fields.                                 *//* -------------------------------------------------------------------- */    eErr = BuildFeatureDefn( pszTableName, hColStmt );    if( eErr != CE_None )        return eErr;#ifdef notdef    if( poFeatureDefn->GetFieldCount() == 0 )    {        CPLError( CE_Failure, CPLE_AppDefined,                   "No column definitions found for table '%s', layer not usable.",                   pszTableName );        return CE_Failure;    }#endif    sqlite3_finalize( hColStmt );    return CE_None;}/************************************************************************//*                           ClearStatement()                           *//************************************************************************/void OGRSQLiteTableLayer::ClearStatement(){    if( hStmt != NULL )    {        CPLDebug( "OGR_SQLITE", "finalize %p", hStmt );	sqlite3_finalize( hStmt );        hStmt = NULL;    }}/************************************************************************//*                            GetStatement()                            *//************************************************************************/sqlite3_stmt *OGRSQLiteTableLayer::GetStatement(){    if( hStmt == NULL )        ResetStatement();    return hStmt;}/************************************************************************//*                           ResetStatement()                           *//************************************************************************/OGRErr OGRSQLiteTableLayer::ResetStatement(){    int rc;    char *pszSQL;    ClearStatement();    iNextShapeId = 0;    if( pszQuery != NULL )        pszSQL = CPLStrdup(             CPLSPrintf( "SELECT _rowid_, * FROM '%s' WHERE %s",                         poFeatureDefn->GetName(),                         pszQuery ) );    else        pszSQL = CPLStrdup( CPLSPrintf( "SELECT _rowid_, * FROM '%s'", 				        poFeatureDefn->GetName() ) );    rc = sqlite3_prepare( poDS->GetDB(), pszSQL, strlen(pszSQL), 	    	          &hStmt, NULL );    CPLDebug( "OGR_SQLITE", "prepare(%s) -> %p", pszSQL, hStmt );    if( rc == SQLITE_OK )    {        CPLFree( pszSQL );    	return OGRERR_NONE;    }    else    {        CPLError( CE_Failure, CPLE_AppDefined,                   "sqlite3_prepare(%s):\n  %s",                   pszSQL, sqlite3_errmsg(poDS->GetDB()) );        hStmt = NULL;        CPLFree( pszSQL );        return OGRERR_FAILURE;    }}/************************************************************************//*                            ResetReading()                            *//************************************************************************/void OGRSQLiteTableLayer::ResetReading(){    ClearStatement();    OGRSQLiteLayer::ResetReading();}/************************************************************************//*                             GetFeature()                             *//************************************************************************/OGRFeature *OGRSQLiteTableLayer::GetFeature( long nFeatureId ){/* -------------------------------------------------------------------- *//*      If we don't have an explicit FID column, just read through      *//*      the result set iteratively to find our target.                  *//* -------------------------------------------------------------------- */    if( pszFIDColumn == NULL )        return OGRSQLiteLayer::GetFeature( nFeatureId );/* -------------------------------------------------------------------- *//*      Setup explicit query statement to fetch the record we want.     *//* -------------------------------------------------------------------- */    const char *pszSQL;    int rc;    ClearStatement();    iNextShapeId = nFeatureId;    pszSQL =        CPLSPrintf( "SELECT _rowid_, * FROM '%s' WHERE \"%s\" = %d",                     poFeatureDefn->GetName(),                     pszFIDColumn, nFeatureId );    CPLDebug( "OGR_SQLITE", "exec(%s)", pszSQL );    rc = sqlite3_prepare( poDS->GetDB(), pszSQL, strlen(pszSQL), 	    	          &hStmt, NULL );/* -------------------------------------------------------------------- *//*      Get the feature if possible.                                    *//* -------------------------------------------------------------------- */    OGRFeature *poFeature = NULL;    if( rc == SQLITE_OK )        poFeature = GetNextRawFeature();    ResetReading();    return poFeature;}/************************************************************************//*                         SetAttributeFilter()                         *//************************************************************************/OGRErr OGRSQLiteTableLayer::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 );    if( pszQuery == NULL || strlen(pszQuery) == 0 )        this->pszQuery = NULL;    else        this->pszQuery = CPLStrdup( pszQuery );    ClearStatement();    return OGRERR_NONE;}/************************************************************************//*                           TestCapability()                           *//************************************************************************/int OGRSQLiteTableLayer::TestCapability( const char * pszCap ){    if( EQUAL(pszCap,OLCSequentialWrite)              || EQUAL(pszCap,OLCRandomWrite) )        return bUpdateAccess;    else if( EQUAL(pszCap,OLCCreateField) )        return bUpdateAccess;    else         return OGRSQLiteLayer::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 OGRSQLiteTableLayer::GetFeatureCount( int bForce ){    if( m_poFilterGeom != NULL && pszGeomColumn != NULL )        return OGRSQLiteLayer::GetFeatureCount( bForce );/* -------------------------------------------------------------------- *//*      Form count SQL.                                                 *//* -------------------------------------------------------------------- */    const char *pszSQL;    if( pszQuery != NULL )        pszSQL = CPLSPrintf( "SELECT count(*) FROM '%s' WHERE %s",                             poFeatureDefn->GetName(), pszQuery );    else        pszSQL = CPLSPrintf( "SELECT count(*) FROM '%s'",                             poFeatureDefn->GetName() );/* -------------------------------------------------------------------- *//*      Execute.                                                        *//* -------------------------------------------------------------------- */    char **papszResult, *pszErrMsg;    int nRowCount, nColCount;    int nResult = -1;    if( sqlite3_get_table( poDS->GetDB(), pszSQL, &papszResult,                            &nColCount, &nRowCount, &pszErrMsg ) != SQLITE_OK )        return -1;    if( nRowCount == 1 && nColCount == 1 )        nResult = atoi(papszResult[1]);    sqlite3_free_table( papszResult );    return nResult;}/************************************************************************//*                           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 *OGRSQLiteTableLayer::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 OGRSQLiteLayer::GetSpatialRef();}/************************************************************************/

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久精品日产第一区二区三区高清版 | 色综合久久88色综合天天6| 日韩欧美一区二区三区在线| 日韩精品视频网| 欧美一区二区三区在线视频| 午夜影视日本亚洲欧洲精品| 91小视频免费看| 日韩欧美黄色影院| 亚洲午夜久久久久久久久久久 | 欧美日韩一区三区四区| 一区二区三区在线视频播放| 欧美日韩中文字幕精品| 蜜臂av日日欢夜夜爽一区| 91亚洲精品久久久蜜桃| 国产成人av在线影院| 一区二区三区自拍| 这里只有精品电影| 亚洲成人自拍一区| 美腿丝袜亚洲三区| 欧美色综合影院| 国产一区二区成人久久免费影院 | 欧美精品一区二区三区很污很色的 | 亚洲欧美激情插| 日一区二区三区| 成人久久18免费网站麻豆 | 国产美女视频91| 一区二区三区在线播| 日韩精品资源二区在线| 大桥未久av一区二区三区中文| 亚洲码国产岛国毛片在线| 日韩欧美久久一区| 91久久精品国产91性色tv| 久久99精品久久久久久国产越南| 综合激情网...| 欧美激情一区二区在线| 3d成人动漫网站| 欧美亚洲国产怡红院影院| 免费人成精品欧美精品| 国产欧美精品一区二区色综合| 精品国产一区二区亚洲人成毛片| 日本黄色一区二区| 92国产精品观看| 成人精品免费看| 国产盗摄视频一区二区三区| 免费亚洲电影在线| 美女免费视频一区二区| 日韩福利视频导航| 五月婷婷久久丁香| 欧美精品一区二区三区蜜臀| 久久久久久久久久美女| 91精品国产综合久久福利软件| 日韩一区二区在线看片| 日韩欧美中文一区二区| 欧美成人一区二区三区| 日韩色在线观看| 亚洲国产精品成人综合| 777奇米四色成人影色区| www.欧美.com| 在线观看精品一区| 国产欧美日韩综合| 国产精品成人在线观看| 亚洲综合一二三区| 日韩精品电影一区亚洲| 极品少妇xxxx偷拍精品少妇| 成人小视频在线| 欧美性一二三区| 欧美亚一区二区| 一本色道久久综合亚洲91| 在线91免费看| 国产欧美日韩在线| 亚洲一区视频在线观看视频| 蜜臀av国产精品久久久久| 菠萝蜜视频在线观看一区| 欧美美女激情18p| 久久精品在这里| 亚洲福利视频一区二区| 亚洲线精品一区二区三区| 日本va欧美va欧美va精品| 成人黄色a**站在线观看| 在线成人午夜影院| 亚洲美女电影在线| 国产成人在线观看免费网站| 欧美午夜一区二区三区 | 欧美剧情片在线观看| 国产精品天干天干在观线| 亚洲午夜三级在线| 久久av中文字幕片| 欧美日本免费一区二区三区| 亚洲欧美影音先锋| 国产一区二区美女| 日韩欧美国产综合| 久久精品国产精品亚洲精品| 欧美日韩免费不卡视频一区二区三区| 国产亚洲福利社区一区| 国产精品资源在线看| 欧美性色aⅴ视频一区日韩精品| 91精品国产色综合久久ai换脸| 一区av在线播放| 欧美午夜精品理论片a级按摩| 依依成人综合视频| 欧美伊人久久大香线蕉综合69| 亚洲人亚洲人成电影网站色| 成人国产精品视频| 亚洲精选一二三| 欧美精品色综合| 精品一区二区三区不卡| 欧美日韩电影在线| 日韩和欧美一区二区三区| 一本大道久久a久久综合| 久久久天堂av| 盗摄精品av一区二区三区| 中文字幕成人av| 精品污污网站免费看| 久久99精品久久久久久动态图 | 欧美一区二区三区性视频| 天天综合天天综合色| 国产日韩欧美不卡在线| 国产91对白在线观看九色| 一个色在线综合| 日韩欧美亚洲另类制服综合在线| 国产在线播精品第三| 一区二区三区四区视频精品免费| 欧美肥妇毛茸茸| 97精品国产露脸对白| 亚洲午夜影视影院在线观看| 久久夜色精品一区| 欧美体内she精高潮| 国产成+人+日韩+欧美+亚洲| 亚洲精品久久久蜜桃| 久久久久久9999| 日韩一区二区在线观看| 91久久精品国产91性色tv| 国产精品亚洲人在线观看| 午夜精品久久久久久久99水蜜桃 | 欧美日本国产一区| 91伊人久久大香线蕉| 国产精品资源站在线| 久久国产福利国产秒拍| 一区二区欧美在线观看| 亚洲婷婷综合色高清在线| 欧美va亚洲va香蕉在线| 欧美一区2区视频在线观看| 欧美三级中文字| 日本韩国一区二区三区| 91成人在线观看喷潮| 色天天综合久久久久综合片| 丁香啪啪综合成人亚洲小说| 国产精品一区二区在线观看网站 | 国产精品小仙女| 国产成人自拍网| jlzzjlzz亚洲女人18| 福利电影一区二区三区| 高潮精品一区videoshd| 成人高清视频免费观看| 97超碰欧美中文字幕| 欧美亚洲图片小说| 久久综合色之久久综合| 精品福利在线导航| 国产欧美日韩在线观看| 亚洲欧美日韩在线| 婷婷中文字幕一区三区| 国产精品一区三区| 91免费视频观看| 欧美videos中文字幕| 国产精品天天看| 日本午夜一本久久久综合| 久久国产精品无码网站| 99久久免费视频.com| 欧美日韩免费一区二区三区| 精品剧情在线观看| 亚洲综合激情小说| 国产精品夜夜嗨| 欧美一级黄色大片| 亚洲天堂久久久久久久| 美女视频黄久久| 欧美日免费三级在线| 国产欧美精品一区| 天天av天天翘天天综合网色鬼国产| 国产精品一区二区三区乱码| 欧美在线观看视频一区二区 | 欧美日韩一区久久| 国产精品久久久久久久久快鸭| 日韩精品色哟哟| 色哟哟一区二区在线观看| 欧美极品少妇xxxxⅹ高跟鞋| 日本欧美久久久久免费播放网| 99精品欧美一区二区三区综合在线| 777色狠狠一区二区三区| 国产精品色一区二区三区| 日韩avvvv在线播放| 在线中文字幕一区二区| 亚洲精品视频在线看| 懂色av一区二区夜夜嗨| 国产偷国产偷精品高清尤物| 久久99精品国产麻豆婷婷洗澡| 日韩欧美国产综合| 久久99国产精品免费| 久久久一区二区三区| 国产成人h网站| 亚洲精品一区二区三区在线观看|