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

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

?? my_param.c

?? unix上的ODBC實現
?? C
字號:
/***************************************************************************                          my_param.c  -  description                             ---------------------    begin                : Wed Sep 8 2001    copyright            : (C) MySQL AB 1995-2002, www.mysql.com    author               : venu ( venu@mysql.com ) ***************************************************************************//*************************************************************************** *                                                                         * *   This program is free software; you can redistribute it and/or modify  * *   it under the terms of the GNU General Public License as published by  * *   the Free Software Foundation; either version 2 of the License, or     * *   (at your option) any later version.                                   * *                                                                         * ***************************************************************************//*************************************************************************** *                                                                         * *  This is a basic sample to demonstrate how to insert or delete or       * *  update data in the table using parameters                              * *                                                                         * ***************************************************************************/#include "my_utility.h" /* MyODBC 3.51 sample utility header *//********************************************************* initialize tables                                     **********************************************************/void my_init_table(SQLHDBC hdbc, SQLHSTMT hstmt){  SQLRETURN   rc;  printf("\nmy_init_table:\n");    /* drop table 'my_demo_param' if it already exists */    printf(" creating table 'my_demo_param'\n");    rc = SQLExecDirect(hstmt,"DROP TABLE if exists my_demo_param",SQL_NTS);    mystmt(hstmt,rc);    /* commit the transaction */    rc = SQLEndTran(SQL_HANDLE_DBC, hdbc, SQL_COMMIT);     mycon(hdbc,rc);    /* create the table 'my_demo_param' */    rc = SQLExecDirect(hstmt,"CREATE TABLE my_demo_param(\                              id   int,\                              auto int primary key auto_increment,\                              name varchar(20),\                              timestamp timestamp(14))",SQL_NTS);    mystmt(hstmt,rc);    /* commit the transaction*/    rc = SQLEndTran(SQL_HANDLE_DBC, hdbc, SQL_COMMIT);    mycon(hdbc,rc);    }/********************************************************* prints the statement resultset                        **********************************************************/int my_print_resultset(SQLHSTMT hstmt){  SQLRETURN   rc;  SQLUINTEGER nRowCount=0, pcColDef;  SQLCHAR     szColName[MAX_NAME_LEN];  SQLCHAR     szData[MAX_COLUMNS][MAX_ROW_DATA_LEN]={0};  SQLSMALLINT nIndex,ncol,pfSqlType, pcbScale, pfNullable;    /* get total number of columns from the resultset */    rc = SQLNumResultCols(hstmt,&ncol);    mystmt(hstmt,rc);    /* print the column names  and do the row bind */    for(nIndex = 1; nIndex <= ncol; nIndex++)    {      rc = SQLDescribeCol(hstmt,nIndex,szColName, MAX_NAME_LEN+1, NULL,                          &pfSqlType,&pcColDef,&pcbScale,&pfNullable);      mystmt(hstmt,rc);      printf(" %s\t",szColName);      rc = SQLBindCol(hstmt,nIndex, SQL_C_CHAR, szData[nIndex-1],                      MAX_ROW_DATA_LEN+1,NULL);      mystmt(hstmt,rc);    }    printf("\n -------------------------------------------\n");    /* now fetch row by row */    rc = SQLFetch(hstmt);    while(rc == SQL_SUCCESS || rc == SQL_SUCCESS_WITH_INFO)    {       nRowCount++;       for(nIndex=0; nIndex< ncol; nIndex++)         printf(" %s\t",szData[nIndex]);            printf("\n");       rc = SQLFetch(hstmt);     }     SQLFreeStmt(hstmt,SQL_UNBIND);     printf("\n total rows fetched:%d\n",nRowCount);     /* free the statement row bind resources */     rc = SQLFreeStmt(hstmt, SQL_UNBIND);     mystmt(hstmt,rc);     /* free the statement cursor */     rc = SQLFreeStmt(hstmt, SQL_CLOSE);     mystmt(hstmt,rc);             return(nRowCount);}/********************************************************* insert data using parameters                          **********************************************************/void my_param_insert(SQLHDBC hdbc, SQLHSTMT hstmt){  SQLRETURN   rc;  SQLINTEGER  id;  SQLCHAR     name[50];  printf("\nmy_param_insert:\n");    /* prepare the insert statement with parameters */    rc = SQLPrepare(hstmt,"INSERT INTO my_demo_param(id,name) VALUES(?,?)",SQL_NTS);    mystmt(hstmt,rc);    /* now supply data to parameter 1 and 2 */    rc = SQLBindParameter(hstmt, 1, SQL_PARAM_INPUT,                           SQL_C_LONG, SQL_INTEGER, 0,0,                          &id, 0, NULL);    mystmt(hstmt,rc);    rc = SQLBindParameter(hstmt, 2, SQL_PARAM_INPUT,                           SQL_C_CHAR, SQL_CHAR, 0,0,                          name, sizeof(name), NULL);    mystmt(hstmt,rc);    /* now insert 10 rows of data */    for (id = 0; id < 10; id++)    {      sprintf(name,"MySQL%d",id);      rc = SQLExecute(hstmt);      mystmt(hstmt,rc);    }        /* Free statement param resorces */    rc = SQLFreeStmt(hstmt, SQL_RESET_PARAMS);    mystmt(hstmt,rc);        /* Free statement cursor resorces */    rc = SQLFreeStmt(hstmt, SQL_CLOSE);    mystmt(hstmt,rc);    /* commit the transaction */    rc = SQLEndTran(SQL_HANDLE_DBC, hdbc, SQL_COMMIT);     mycon(hdbc,rc);    /* Now fetch and verify the data */    rc = SQLExecDirect(hstmt, "SELECT * FROM my_demo_param",SQL_NTS);    mystmt(hstmt,rc);    assert(10 == my_print_resultset(hstmt));}/********************************************************* update data using parameters                          **********************************************************/void my_param_update(SQLHDBC hdbc, SQLHSTMT hstmt){  SQLRETURN   rc;  SQLINTEGER  id=9, nRowCount;  SQLCHAR     name[]="update";  printf("\nmy_param_update:\n");    /* prepare the insert statement with parameters */    rc = SQLPrepare(hstmt,"UPDATE my_demo_param set name = ? WHERE id = ?",SQL_NTS);    mystmt(hstmt,rc);    /* now supply data to parameter 1 and 2 */        rc = SQLBindParameter(hstmt, 1, SQL_PARAM_INPUT,                           SQL_C_CHAR, SQL_CHAR, 0,0,                          name, sizeof(name), NULL);    mystmt(hstmt,rc);    rc = SQLBindParameter(hstmt, 2, SQL_PARAM_INPUT,                           SQL_C_LONG, SQL_INTEGER, 0,0,                          &id, 0, NULL);    mystmt(hstmt,rc);    /* now execute the update statement */    rc = SQLExecute(hstmt);    mystmt(hstmt,rc);        /* check the rows affected by the update statement */    rc = SQLRowCount(hstmt, &nRowCount);    mystmt(hstmt,rc);    printf("\n total rows updated:%d\n",nRowCount);    assert( nRowCount == 1);        /* Free statement param resorces */    rc = SQLFreeStmt(hstmt, SQL_RESET_PARAMS);    mystmt(hstmt,rc);        /* Free statement cursor resorces */    rc = SQLFreeStmt(hstmt, SQL_CLOSE);    mystmt(hstmt,rc);    /* commit the transaction */    rc = SQLEndTran(SQL_HANDLE_DBC, hdbc, SQL_COMMIT);     mycon(hdbc,rc);    /* Now fetch and verify the data */    rc = SQLExecDirect(hstmt, "SELECT * FROM my_demo_param",SQL_NTS);    mystmt(hstmt,rc);    assert(10 == my_print_resultset(hstmt));}/********************************************************* delete data using parameters                          **********************************************************/void my_param_delete(SQLHDBC hdbc, SQLHSTMT hstmt){  SQLRETURN   rc;  SQLINTEGER  id, nRowCount;  printf("\nmy_param_delete:\n");        /* supply data to parameter 1 */        rc = SQLBindParameter(hstmt, 1, SQL_PARAM_INPUT,                           SQL_C_LONG, SQL_INTEGER, 0,0,                          &id, 0, NULL);    mystmt(hstmt,rc);    /* execute the DELETE STATEMENT to delete 5th row  */    id = 5;    rc = SQLExecDirect(hstmt,"DELETE FROM my_demo_param WHERE id = ?",SQL_NTS);    mystmt(hstmt,rc);        /* check the rows affected by the update statement */    rc = SQLRowCount(hstmt, &nRowCount);    mystmt(hstmt,rc);    printf(" total rows deleted:%d\n",nRowCount);    assert( nRowCount == 1);    /* execute the DELETE STATEMENT to delete 8th row  */    id = 8;    rc = SQLExecDirect(hstmt,"DELETE FROM my_demo_param WHERE id = ?",SQL_NTS);    mystmt(hstmt,rc);        /* check the rows affected by the update statement */    rc = SQLRowCount(hstmt, &nRowCount);    mystmt(hstmt,rc);    printf(" total rows deleted:%d\n",nRowCount);    assert( nRowCount == 1);        /* Free statement param resorces */    rc = SQLFreeStmt(hstmt, SQL_RESET_PARAMS);    mystmt(hstmt,rc);        /* Free statement cursor resorces */    rc = SQLFreeStmt(hstmt, SQL_CLOSE);    mystmt(hstmt,rc);    /* commit the transaction */    rc = SQLEndTran(SQL_HANDLE_DBC, hdbc, SQL_COMMIT);     mycon(hdbc,rc);    /* Now fetch and verify the data */    rc = SQLExecDirect(hstmt, "SELECT * FROM my_demo_param",SQL_NTS);    mystmt(hstmt,rc);    assert(8 == my_print_resultset(hstmt));}/********************************************************* main routine                                          **********************************************************/int main(int argc, char *argv[]){  SQLHENV    henv;  SQLHDBC    hdbc;   SQLHSTMT   hstmt;  SQLINTEGER narg;      /*     *  show the usage string when the user asks for this    */          printf("***********************************************\n");      printf("usage: my_param [DSN] [UID] [PWD] \n");        printf("***********************************************\n");         /*     * if connection string supplied through arguments, overrite     * the default one..    */    for(narg = 1; narg < argc; narg++)    {           if ( narg == 1 )        mydsn = argv[1];      else if ( narg == 2 )        myuid = argv[2];      else if ( narg == 3 )        mypwd = argv[3];          }       /*      * connect to MySQL server    */    myconnect(&henv,&hdbc,&hstmt);     /*      * initialize table    */    my_init_table(hdbc, hstmt);    /*      * insert data using parameters    */    my_param_insert(hdbc, hstmt);    /*      * parameter update     */    my_param_update(hdbc, hstmt);    /*      * parameter delete    */    my_param_delete(hdbc, hstmt);    /*      * disconnect from the server, by freeing all resources    */    mydisconnect(&henv,&hdbc,&hstmt);  return(0);} 

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
麻豆视频观看网址久久| 国产精品国产三级国产aⅴ原创| 一区二区三区在线视频观看58| 成人爽a毛片一区二区免费| 精品电影一区二区| 成人一区在线观看| 一区二区三区国产精品| 欧美三级日韩三级国产三级| 亚洲成人一区二区在线观看| 在线综合视频播放| 国产真实乱子伦精品视频| 国产日韩av一区| 在线看国产一区| 免费高清在线一区| 国产日韩视频一区二区三区| 99精品视频一区二区| 香蕉影视欧美成人| 26uuu成人网一区二区三区| 成人免费电影视频| 亚洲国产成人精品视频| 日韩欧美久久久| av福利精品导航| 天堂在线亚洲视频| 国产亚洲va综合人人澡精品| 色综合久久综合网欧美综合网| 天堂影院一区二区| 国产精品入口麻豆原神| 欧美三级电影一区| 国产在线精品国自产拍免费| 亚洲日本va在线观看| 欧美一区三区四区| 99久久久久久| 毛片av一区二区| 综合在线观看色| 日韩视频在线你懂得| 成人av在线网站| 久久超碰97中文字幕| 亚洲色图制服诱惑| 久久蜜臀精品av| 欧美福利一区二区| 99精品偷自拍| 国产成人av一区二区| 丝袜美腿成人在线| 亚洲视频 欧洲视频| 国产亚洲美州欧州综合国| 欧美群妇大交群中文字幕| 99久久99久久综合| 狠狠色综合播放一区二区| 亚洲一区二区不卡免费| 国产精品色哟哟| 国产午夜精品一区二区三区视频 | 国产精品成人免费在线| 91精品国产综合久久小美女| 色综合天天综合| 国产成人免费视频一区| 蜜桃视频第一区免费观看| 亚洲午夜电影在线观看| 一区在线中文字幕| 国产午夜精品久久久久久久 | 精品国产免费一区二区三区四区| 日本韩国视频一区二区| 成+人+亚洲+综合天堂| 国产乱码一区二区三区| 麻豆极品一区二区三区| 午夜成人免费电影| 一区二区三区在线观看国产| 亚洲欧洲在线观看av| 国产欧美一区二区精品性色超碰 | 欧美中文字幕一区二区三区| 成人美女在线观看| 丁香激情综合五月| 国产91在线观看| 国产成人午夜99999| 国内成人精品2018免费看| 美女看a上一区| 视频一区欧美精品| 日产欧产美韩系列久久99| 五月天激情小说综合| 亚洲成人av一区| 午夜av一区二区三区| 午夜成人免费视频| 日本aⅴ免费视频一区二区三区| 日韩福利视频网| 日韩电影一区二区三区四区| 琪琪久久久久日韩精品| 免费久久精品视频| 久久精品国产免费看久久精品| 毛片av一区二区| 国产精品99久久久久久久女警 | 久久久久亚洲综合| 国产午夜亚洲精品午夜鲁丝片| 国产精品久久久久久久浪潮网站| 国产精品国产三级国产aⅴ入口| 国产精品福利一区二区三区| 亚洲天堂成人网| 亚洲第一狼人社区| 蜜臀久久久99精品久久久久久| 久久超碰97中文字幕| 成人黄色大片在线观看| 日本高清不卡视频| 91麻豆精品国产自产在线观看一区| 欧美一级日韩不卡播放免费| 久久久久久久综合日本| 亚洲欧美一区二区在线观看| 亚洲综合色自拍一区| 免费在线观看一区| 国产aⅴ综合色| 欧美亚洲禁片免费| 2021中文字幕一区亚洲| 日韩美女啊v在线免费观看| 午夜精品在线看| 成人综合在线视频| 91久久免费观看| 26uuu精品一区二区| 亚洲另类在线一区| 久久国产免费看| 色综合久久综合网97色综合| 欧美一区二区观看视频| 中日韩av电影| 五月激情综合色| 成人美女视频在线看| 欧美一级午夜免费电影| 亚洲三级电影网站| 麻豆成人综合网| 色综合天天在线| 国产人久久人人人人爽| 亚洲国产精品天堂| 成人性生交大片免费看视频在线 | 精品欧美一区二区三区精品久久| 国产精品久久久久久久久果冻传媒| 亚洲一区二区三区精品在线| 国产精品 日产精品 欧美精品| 欧美网站一区二区| 欧美国产一区二区在线观看| 亚洲国产精品久久人人爱蜜臀| 国产999精品久久久久久绿帽| 欧美一区二区私人影院日本| 亚洲另类色综合网站| 丰满岳乱妇一区二区三区| 日韩欧美国产午夜精品| 一区二区三区加勒比av| 99久久精品情趣| 国产三级一区二区三区| 日本免费新一区视频| 在线看日本不卡| 中文字幕一区二区视频| 国产精品一级二级三级| 日韩一级完整毛片| 婷婷亚洲久悠悠色悠在线播放| 色偷偷久久人人79超碰人人澡| 国产欧美精品一区二区色综合| 免费在线观看不卡| 欧美一区二区久久| 人妖欧美一区二区| 91麻豆精品国产无毒不卡在线观看| 亚洲综合色在线| 一本久久a久久免费精品不卡| 中文字幕不卡在线播放| 国产精品99久久久久久久女警| 精品成人在线观看| 青青草精品视频| 欧美一区二区三区性视频| 亚洲成人高清在线| 欧美福利视频导航| 日本视频一区二区三区| 欧美一区永久视频免费观看| 日本亚洲三级在线| 911精品国产一区二区在线| 亚洲成人av福利| 91麻豆精品国产| 日韩va亚洲va欧美va久久| 欧美日韩美女一区二区| 亚洲成人精品一区| 91精品国产91热久久久做人人| 天涯成人国产亚洲精品一区av| 欧美日本韩国一区| 久久成人羞羞网站| 久久久久久影视| av成人免费在线观看| 亚洲欧美精品午睡沙发| 在线观看免费亚洲| 亚洲成a人在线观看| 欧美妇女性影城| 国内外成人在线视频| 国产精品五月天| 91精品1区2区| 日日摸夜夜添夜夜添国产精品| 91精品国产欧美一区二区18 | 亚洲图片欧美一区| 3atv一区二区三区| 狠狠狠色丁香婷婷综合激情| 国产视频一区不卡| 色诱视频网站一区| 奇米影视一区二区三区| 国产午夜精品久久久久久免费视| 91蜜桃视频在线| 日本免费新一区视频 | 亚洲欧洲av在线| 欧美剧情电影在线观看完整版免费励志电影| 午夜国产精品一区|