青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

r2100

  C++博客 :: 首頁(yè) :: 聯(lián)系 :: 聚合  :: 管理
  8 Posts :: 9 Stories :: 2 Comments :: 0 Trackbacks

常用鏈接

留言簿(3)

我參與的團(tuán)隊(duì)

搜索

  •  

最新評(píng)論

閱讀排行榜

評(píng)論排行榜

SQLExecDirect函數(shù)源代碼
static SQLRETURN
ODBCExecDirect(ODBCStmt 
*stmt, SQLCHAR *szSqlStr, SQLINTEGER nSqlStr)
{
    
char *query;
    MapiMsg ret;
    MapiHdl hdl;

    hdl 
= stmt->hdl;

    
if (stmt->State >= EXECUTED1 || (stmt->State == EXECUTED0 && mapi_more_results(hdl))) {
        
/* Invalid cursor state */
        addStmtError(stmt, 
"24000", NULL, 0);
        
return SQL_ERROR;
    }

    
/* TODO: convert ODBC escape sequences ( {d 'value'} or {t 'value'} or
       {ts 'value'} or {escape 'e-char'} or {oj outer-join} or
       {fn scalar-function} etc. ) to MonetDB SQL syntax 
*/
    query 
= ODBCTranslateSQL(szSqlStr, (size_t) nSqlStr, stmt->noScan);

    ODBCResetStmt(stmt);

#ifdef ODBCDEBUG
    ODBCLOG(
"SQLExecDirect: \"%s\"\n", query);
#endif

    ret 
= mapi_query_handle(hdl, query);
    free(query);
    
switch (ret) {
    
case MOK:
        
break;
    
case MTIMEOUT:
        
/* Communication link failure */
        addStmtError(stmt, 
"08S01", mapi_error_str(stmt->Dbc->mid), 0);
        
return SQL_ERROR;
    
default:
        
/* General error */
        addStmtError(stmt, 
"HY000", mapi_error_str(stmt->Dbc->mid), 0);
        
return SQL_ERROR;
    }

    
/* now get the result data and store it to our internal data structure */

    
return ODBCInitResult(stmt);
}

As mentioned earlier, it is more efficient to reuse statements than to drop them and allocate new ones. Before executing a new SQL statement on a statement, applications should be sure that the current statement settings are appropriate. These include statement attributes, parameter bindings, and result set bindings. Generally, parameters and result sets for the old SQL statement need to be unbound (by calling SQLFreeStmt with the SQL_RESET_PARAMS and SQL_UNBIND options) and rebound for the new SQL statement.

When the application has finished using the statement, it calls SQLFreeHandle to free the statement. After freeing the statement, it is an application programming error to use the statement's handle in a call to an ODBC function; doing so has undefined but probably fatal consequences.

When SQLFreeHandle is called, the driver releases the structure used to store information about the statement.

SQLDisconnect automatically frees all statements on a connection.


         
/**********************************************
 * ODBCStmt.c
 *
 * Description:
 * This file contains the functions which operate on
 * ODBC statement structures/objects (see ODBCStmt.h).
 *
 * Author: Martin van Dinther
 * Date  : 30 aug 2002
 *
 *********************************************
*/

#include 
"ODBCGlobal.h"
#include 
"ODBCStmt.h"

#define ODBC_STMT_MAGIC_NR  5461    /* for internal sanity check only */


/*
 * Creates a new allocated ODBCStmt object and initializes it.
 *
 * Precondition: none
 * Postcondition: returns a new ODBCStmt object
 
*/
ODBCStmt 
*
newODBCStmt(ODBCDbc 
*dbc)
{
    ODBCStmt 
*stmt = (ODBCStmt *) malloc(sizeof(ODBCStmt));
    assert(stmt);

    assert(dbc);
    assert(dbc
->mid);

    
if (stmt == NULL) {
        
/* Memory allocation error */
        addDbcError(dbc, 
"HY001", NULL, 0);
        
return NULL;
    }

    stmt
->Dbc = dbc;
    stmt
->Error = NULL;
    stmt
->RetrievedErrors = 0;

    stmt
->State = INITED;
    stmt
->hdl = mapi_new_handle(dbc->mid);
    
if (stmt->hdl == NULL) {
        
/* Memory allocation error */
        addDbcError(dbc, 
"HY001", NULL, 0);
        free(stmt);
        
return NULL;
    }
    assert(stmt
->hdl);

    stmt
->currentRow = 0;
    stmt
->startRow = 0;
    stmt
->rowSetSize = 0;
    stmt
->queryid = -1;
    stmt
->nparams = 0;
    stmt
->querytype = -1;
    stmt
->rowcount = 0;

    
/* add this stmt to the administrative linked stmt list */
    stmt
->next = dbc->FirstStmt;
    dbc
->FirstStmt = stmt;

    stmt
->cursorType = SQL_CURSOR_FORWARD_ONLY;
    stmt
->cursorScrollable = SQL_NONSCROLLABLE;
    stmt
->retrieveData = SQL_RD_ON;
    stmt
->noScan = SQL_NOSCAN_OFF;

    stmt
->ApplRowDescr = newODBCDesc(dbc);
    stmt
->ApplParamDescr = newODBCDesc(dbc);
    stmt
->ImplRowDescr = newODBCDesc(dbc);
    stmt
->ImplParamDescr = newODBCDesc(dbc);
    stmt
->AutoApplRowDescr = stmt->ApplRowDescr;
    stmt
->AutoApplParamDescr = stmt->ApplParamDescr;

    
if (stmt->ApplRowDescr == NULL || stmt->ApplParamDescr == NULL || stmt->ImplRowDescr == NULL || stmt->ImplParamDescr == NULL) {
        destroyODBCStmt(stmt);
        
return NULL;
    }

    stmt
->ApplRowDescr->sql_desc_alloc_type = SQL_DESC_ALLOC_AUTO;
    stmt
->ApplParamDescr->sql_desc_alloc_type = SQL_DESC_ALLOC_AUTO;
    stmt
->ImplRowDescr->sql_desc_alloc_type = SQL_DESC_ALLOC_AUTO;
    stmt
->ImplParamDescr->sql_desc_alloc_type = SQL_DESC_ALLOC_AUTO;
    stmt
->ImplRowDescr->Stmt = stmt;
    stmt
->ImplParamDescr->Stmt = stmt;

    stmt
->Type = ODBC_STMT_MAGIC_NR;    /* set it valid */

    
return stmt;
}

SQLFreeHandle
ODBCFreeStmt_(ODBCStmt 
*stmt)
{
    
/* check if statement is not active */
    
if (stmt->State >= EXECUTED0) {
        
/* should be closed first */
        
if (SQLFreeStmt_(stmt, SQL_CLOSE) == SQL_ERROR)
            
return SQL_ERROR;
    }

    
/* Ready to destroy the stmt handle */
    destroyODBCStmt(stmt);
    
return SQL_SUCCESS;
}


SQLFreeStmt

SQLFreeStmt_(ODBCStmt 
*stmt, SQLUSMALLINT option)
{
    
switch (option) {
    
case SQL_CLOSE:
        
/* Note: this option is also called from SQLCancel() and
           SQLCloseCursor(), so be careful when changing the code 
*/
        
/* close cursor, discard result set, set to prepared */
        setODBCDescRecCount(stmt
->ImplRowDescr, 0);
        stmt
->currentRow = 0;
        stmt
->startRow = 0;
        stmt
->rowSetSize = 0;

        
if (stmt->State == EXECUTED0)
            stmt
->State = stmt->queryid >= 0 ? PREPARED0 : INITED;
        
else if (stmt->State >= EXECUTED1)
            stmt
->State = stmt->queryid >= 0 ? PREPARED1 : INITED;

        
/* Important: do not destroy the bind parameters and columns! */
        
return SQL_SUCCESS;
    
case SQL_DROP:
        
return ODBCFreeStmt_(stmt);
    
case SQL_UNBIND:
        setODBCDescRecCount(stmt
->ApplRowDescr, 0);
        
return SQL_SUCCESS;
    
case SQL_RESET_PARAMS:
        setODBCDescRecCount(stmt
->ApplParamDescr, 0);
        setODBCDescRecCount(stmt
->ImplParamDescr, 0);
        mapi_clear_params(stmt
->hdl);
        
return SQL_SUCCESS;
    
default:
        
/* Invalid attribute/option identifier */
        addStmtError(stmt, 
"HY092", NULL, 0);
        
return SQL_ERROR;
    }

    
/* not reached */
}

SQLHSTMT的結(jié)構(gòu)
typedef 
struct tODBCDRIVERSTMT {
    
/* Stmt properties */
    
int Type;        /* structure type, used for handle validy test */
    ODBCError 
*Error;    /* pointer to an Error object or NULL */
    
int RetrievedErrors;    /* # of errors already retrieved by SQLError */
    ODBCDbc 
*Dbc;        /* Connection context */
    
struct tODBCDRIVERSTMT *next;    /* the linked list of stmt's in this Dbc */
    
enum StatementState State;    /* needed to detect invalid cursor state */
    MapiHdl hdl;

    unsigned 
int rowcount;    /* # affected rows */

    
/* startRow is the row number of first row in the result
       set (0 based); rowSetSize is the number of rows in the
       current result set; currentRow is the row number of the
       current row within the current result set 
*/
    unsigned 
int currentRow;
    unsigned 
int startRow;
    unsigned 
int rowSetSize;

    unsigned 
int currentCol; /* used by SQLGetData() */
    SQLINTEGER retrieved;    
/* amount of data retrieved */
    
int queryid;        /* the query to be executed */
    
int nparams;        /* the number of parameters expected */

    
int querytype;        /* query type as returned by server */

    SQLUINTEGER cursorType;
    SQLUINTEGER cursorScrollable;
    SQLUINTEGER retrieveData;
    SQLUINTEGER noScan;

    ODBCDesc 
*ApplRowDescr;    /* Application Row Descriptor (ARD) */
    ODBCDesc 
*ApplParamDescr; /* Application Parameter Descriptor (APD) */
    ODBCDesc 
*ImplRowDescr;    /* Implementation Row Descriptor (IRD) */
    ODBCDesc 
*ImplParamDescr; /* Implementation Parameter Descriptor (IPD) */

    ODBCDesc 
*AutoApplRowDescr; /* Auto-allocated ARD */
    ODBCDesc 
*AutoApplParamDescr; /* Auto-allocated APD */

    
/* Stmt children: none yet */
} ODBCStmt;






posted on 2008-09-11 11:31 r2100 閱讀(1175) 評(píng)論(2)  編輯 收藏 引用

Feedback

# re: http://msdn.microsoft.com/en-us/library/ms716303(VS.85).aspx 2008-09-11 11:32 r2100
但是一直沒(méi)有找到實(shí)例,郁悶  回復(fù)  更多評(píng)論
  

# re: http://msdn.microsoft.com/en-us/library/ms716303(VS.85).aspx 2009-01-28 18:01 張三
安裝不成。。。  回復(fù)  更多評(píng)論
  


只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            一区二区三区欧美在线| 久久久久国产精品一区二区| 一本色道久久综合一区| 欧美无砖砖区免费| 亚洲综合日韩在线| 久久亚洲精品欧美| 亚洲国产经典视频| 欧美日韩国产综合视频在线观看中文| 日韩一级黄色av| 亚洲欧美另类在线| 一区二区视频欧美| 欧美日本一道本| 亚洲欧美视频| 欧美成人精品| 亚洲永久精品国产| 国产一区二区三区丝袜 | 在线电影一区| 欧美紧缚bdsm在线视频| 亚洲一区二区黄色| 蜜桃精品久久久久久久免费影院| 亚洲精品婷婷| 国产日韩精品一区观看| 久久综合给合| 亚洲男女自偷自拍图片另类| 免费成人高清视频| 亚洲一区二区三区成人在线视频精品| 国产主播精品| 欧美日韩不卡视频| 久久精品一级爱片| 在线综合+亚洲+欧美中文字幕| 久久久久国产精品www| 一区二区三区四区五区精品视频 | 国产欧美日韩三级| 欧美国产激情二区三区| 午夜久久影院| 亚洲日本久久| 久久久久久久久伊人| 一区二区三区欧美在线| 在线观看亚洲视频啊啊啊啊| 国产精品久久久久免费a∨大胸| 久久久之久亚州精品露出| 一本久道久久久| 久久久精彩视频| 欧美三区在线观看| 欧美专区在线播放| 夜夜嗨av色一区二区不卡| 免费亚洲电影在线| 欧美在线一级va免费观看| 99re6这里只有精品视频在线观看| 国产一区91| 国产精品亚洲一区二区三区在线| 欧美 日韩 国产精品免费观看| 欧美一区二区三区成人| 一本色道久久综合亚洲精品婷婷| 亚洲丶国产丶欧美一区二区三区| 久久精品国产999大香线蕉| 亚洲一区二区成人| 亚洲毛片av在线| 亚洲国产三级| 尤物精品在线| 国模套图日韩精品一区二区| 国产精品中文字幕欧美| 国产精品久久| 国产精品久久久久影院亚瑟| 欧美日韩在线播放三区四区| 国产精品中文字幕欧美| 欧美黄色一级视频| 男人的天堂亚洲| 久久人体大胆视频| 久久噜噜亚洲综合| 久久野战av| 久久五月婷婷丁香社区| 久久精品国产一区二区电影| 欧美在线免费| 久久久久高清| 久久综合久久综合这里只有精品 | 亚洲人成网站在线播| 欧美国产综合| 亚洲国产欧美久久| 亚洲黄色在线看| 99在线|亚洲一区二区| 日韩视频免费在线| 一区二区激情视频| 亚洲影视在线| 欧美一区二区三区在线观看视频| 欧美一区二视频| 久久久另类综合| 免费在线成人| 欧美日韩国语| 国产精品一区一区三区| 国产一区二区三区四区五区美女 | 久久国产主播| 嫩模写真一区二区三区三州| 亚洲国产成人av| 亚洲精品乱码久久久久久日本蜜臀 | 亚洲美女少妇无套啪啪呻吟| 一本色道久久综合亚洲精品高清| 中文亚洲视频在线| 欧美一区二区三区免费看| 久久精品国产清自在天天线| 男人的天堂亚洲| 亚洲免费观看高清完整版在线观看熊 | 美女网站久久| 91久久夜色精品国产九色| 99国产精品久久久久久久| 亚洲欧美日本国产有色| 久久全球大尺度高清视频| 欧美成人蜜桃| 国产精品色婷婷久久58| 国内外成人免费激情在线视频网站 | 久久女同互慰一区二区三区| 亚洲电影av在线| 亚洲视频图片小说| 久久久久久69| 欧美日韩一区视频| 韩国女主播一区二区三区| 日韩西西人体444www| 久久国产色av| 亚洲人永久免费| 欧美一级理论片| 欧美日韩成人在线视频| 国产日韩综合一区二区性色av| 亚洲欧洲日产国产综合网| 午夜精品久久| 亚洲第一页在线| 性色av一区二区怡红| 欧美伦理在线观看| 韩国欧美一区| 亚洲主播在线播放| 欧美激情久久久久久| 亚洲欧美在线aaa| 欧美日韩精品免费在线观看视频| 国产亚洲欧美日韩一区二区| 一个色综合导航| 麻豆乱码国产一区二区三区| 亚洲视频在线二区| 欧美第一黄色网| 伊人春色精品| 久久成人国产| 一区二区三区精品视频在线观看| 噜噜噜躁狠狠躁狠狠精品视频 | 久久天天躁狠狠躁夜夜爽蜜月| 日韩视频不卡| 欧美粗暴jizz性欧美20| 经典三级久久| 久久精品视频在线免费观看| 亚洲视频电影在线| 欧美久久婷婷综合色| 亚洲国产精品va在线看黑人| 久久久久国产精品一区二区| 亚洲欧美日本精品| 国产精品成人免费精品自在线观看| 91久久精品国产91性色| 欧美成年人网站| 久久久久久亚洲综合影院红桃| 国产欧美综合在线| 性xx色xx综合久久久xx| 在线视频日韩| 国产精品久久久久9999吃药| 亚洲一区一卡| 一区二区三区国产在线| 欧美日韩在线一区二区| 一区二区三区视频在线播放| 亚洲精品视频免费观看| 欧美高清影院| 99热这里只有精品8| 亚洲三级影院| 欧美日韩国产免费| 亚洲午夜免费视频| 亚洲网址在线| 国产九九精品视频| 欧美一区二区视频观看视频| 亚洲女与黑人做爰| 国产日韩欧美不卡| 久久婷婷国产综合尤物精品 | 久久伊人一区二区| 亚洲第一中文字幕| 欧美激情视频一区二区三区不卡| 免费人成精品欧美精品| 日韩写真视频在线观看| 99日韩精品| 国产精品视频自拍| 久久免费偷拍视频| 免费久久精品视频| 一本高清dvd不卡在线观看| 一道本一区二区| 国产欧美一区二区三区在线老狼 | 欧美精品成人一区二区在线观看| 日韩午夜精品视频| 亚洲午夜精品福利| 国产午夜精品视频| 免费在线看成人av| 欧美日韩国产一区二区三区地区| 亚洲一区日韩| 久久久久久亚洲精品杨幂换脸| 亚洲免费电影在线观看| 亚洲欧美另类在线观看| 最近中文字幕日韩精品| 亚洲最新在线视频| 国内精品亚洲|