亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

利 用 ISAPI 實 現 向 數 據 庫 中 添 加 記 錄 (四)

2019-11-18 22:40:13
字體:
來源:轉載
供稿:網友
4、ISAPI 應 用 程 序 的 編 寫

   我 們 利 用 SQL 語 句 可 嵌 入 在 應 用 程 序 中 的 特 點, 把 SQL 的 有 關 請 求 語 句 嵌 入 在 ISAPI 交 互 程 序 中。 ISAPI 交 互 程 序 用 Visual C++ 編 寫, 以 下 是 實 現 向 中 藥 數 據 庫 的 表 CMT1 中 添 加 記 錄 的 主 要 程 序 段:

  
   // 建 立 一 個 CZY 類 的 成 員 函 數 FileWrite1Entry, 實 現 向 中 藥 數 據 庫 的 表 CMT1 中 添 加 記 錄
void CZY::FileWrite1Entry(CHttpServerContext* pCtxt, LPTSTR pstrFileName)
{
    const unsigned REC_NUM=1;    // REC_NUM(數據文件中記錄個數)
    const unsigned LINE=9;        // LINE(表中數據域的個數)
    const unsigned COLUMN=6000;    // COLUMN(每個數據域中字符的最大個數)
    char c,data[LINE][COLUMN];
    FILE *fp;
    StartContent(pCtxt);        //HTML頭格式
    WriteTitle(pCtxt);            //HTML標題
    Cstring stringSql;
    Cstring strQuery;
    Cstring strOutput;
    Cstring pstrZY00,pstrZY01,pstrZY02,pstrZY03,pstrZY04,pstrZY05,
            pstrZY06,pstrZY07,pstrZY08;
    //以"讀"的方式打開文件名為pstrFileName的文件
    if (!(fp = fopen (pstrFileName, "r")))
    {
        *pCtxt    << "< center>< font color='red'>Warning: < /font>Cannot open this file.< /center>";
        return;
    }
    //從文件中讀取數據
    for(int k=0; k< REC_NUM; k++)
    {
        for(int I=0; I< LINE; I++)
        {
            //忽略"{"以前的說明性字符
            do{
                c=getc(fp);
            }while(c!='{');
            //讀取"{"和"}"之間的字符數據
            for(int j=0; j< COLUMN; j++)
            {
                c=getc(fp);
                if(c=='}')
                {
                    data[I][j]='/0';
                    break;
                }
                else if((c=='/r')||(c=='/n')||(c=='{'))
                {
                    j--;
                }
                else
                {
                    data[I][j]=c;
                }
            }
        }
    }
    fclose(fp)
    //把從文件中讀取的數據賦給相應的字符型變量
    pstrZY00 = data[0];
    pstrZY01 = data[1];
    pstrZY02 = data[2];
    pstrZY03 = data[3];
    pstrZY04 = data[4];
    pstrZY05 = data[5];
    pstrZY06 = data[6];
    pstrZY07 = data[7];
    pstrZY08 = data[8];
    //創建數據庫對象
    Cdatabase db;
    // 確認數據
    if(     !strcmp(pstrZY00,NULLSTRING) || !strcmp(pstrZY01,NULLSTRING)||
        !strcmp(pstrZY03,NULLSTRING) || !strcmp(pstrZY05,NULLSTRING)||
        !strcmp(pstrZY06,NULLSTRING) || !strcmp(pstrZY07,NULLSTRING)||
        !strcmp(pstrZY08,NULLSTRING)    )
    {
        *pCtxt    < < "< br>< center>"
                << "Please be certain to enter your ZY00,ZY01,ZY03,ZY05,ZY06,ZY07,ZY08. /r/n"
                < < "Thank you."
                < < "< /center>";
        return;
    }
    // 格式化添加記錄的條件
    strQuery.Format("ZY00 = '%-.20s'", pstrZY00);
    // 打開數據庫對象,如果此對象不存在就退出
    if(!db.Open(ZyDB, //lpszDSN
        FALSE, //bExclusive
        FALSE, //bReadOnly
        CONNECTSTRING, //lpszConnect
        FALSE)) //bUseCursorLib
    {
        *pCtxt < < "Could not open the database.";
        return;
    }
    //創建RECOREDSET類的數據庫表對象
    CZyCMT1 rsZy(&db);
    //指定格式化的添加記錄的條件給表對象
    rsZy.m_strFilter = strQuery;
    //打開表對象,如果不能打開就CATCH異常處理
    try
    {
        if(rsZy.Open(Crecordset::dynaset))
        {
            //如果想添加的記錄已經存在于數據庫的表中,就給出IDS_ONFILE中包含的反饋信息
            if(!rsZy.IsBOF())
            {
                strOutput.Format(IDS_ONFILE, pstrZY00, SCRipTPATH);
            }
            else
            {
                // 構造插入記錄語句
                stringSql.Format("Insert into CMT1 (ZY00,ZY01,ZY02,ZY03,ZY04,ZY05,ZY06,"
                    "ZY07,ZY08) VALUES('%-.20s','%-.50s','%s', '%-.80s','%s',"
                    "'%-.100s','%-.9s','%-.5s','%-.2s')", pstrZY00,pstrZY01,                     pstrZY02,pstrZY03,pstrZY04,pstrZY05,pstrZY06,pstrZY07,pstrZY08);
                //執行插入記錄命令。如果成功給出IDS_THANKYOU中包含的反饋信息,
                //否則CATCH異常處理
                try
                {
                    db.ExecuteSQL(stringSql);
                    strOutput.Format(IDS_THANKYOU, pstrZY00, SCRIPTPATH);
                }
                catch (CDBException* pEX)
                {
                    TCHAR szError[1024];
                    if(pEX->GetErrorMessage(szError, sizeof(szError)))
                        strOutput.Format(IDS_EXCEPTION, szError, SCRIPTPATH);
                    else
                        strOutput.Format(IDS_UNKNOWN, SCRIPTPATH);
                }
            }
        }
        else
            //如果數據庫表對象不能打開,給出IDS_UNKNOWN中包含的反饋信息
            strOutput.Format(IDS_UNKNOWN, SCRIPTPATH);
    }
    catch(CDBException* pEX)
    {
        TCHAR szError[1024];
        if(pEX->GetErrorMessage(szError, sizeof(szError)))
            strOutput.Format(IDS_EXCEPTION, szError, SCRIPTPATH);
        else
            strOutput.Format(IDS_UNKNOWN, SCRIPTPATH);
    }
    rsZy.Close();        //關閉表對象
    db.Close();        //關閉數據庫
    //給用戶顯示反饋的信息
    *pCtxt < < strOutput;
    EndContent(pCtxt);    //HTML尾格式
}


  

   編 譯 好 的 ISAPI 動 態 連 接 庫 程 序 將 其 置 于 /Scripts 目 錄 中。 /Scripts 是 交 互 程 序 的 虛 擬 目 錄。 它 可 通 過 WWW 服 務 管 理 器 來 設 定。 當 WWW 第 一 次 被 安 裝 時, 缺 省 的 ISAPI 可 執 行 的 虛 擬 目 錄 是 /Scripts。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
成人疯狂猛交xxx| 国产精品免费网站| 欧美成人免费视频| 伊人久久综合97精品| 日韩中文字幕免费视频| 色av中文字幕一区| 琪琪亚洲精品午夜在线| 久久久久久久一区二区| 日本sm极度另类视频| 午夜精品视频在线| 国产成人免费av电影| 国产成人精品优优av| 成人伊人精品色xxxx视频| 亚洲片国产一区一级在线观看| 国产精品视频999| 精品国产91久久久久久老师| 日韩在线视频观看正片免费网站| 九九综合九九综合| 92看片淫黄大片欧美看国产片| 亚洲第一天堂无码专区| 欧美日韩高清在线观看| 日韩精品黄色网| 91精品国产91久久久久久最新| 久久久国产精彩视频美女艺术照福利| 日韩国产欧美区| 日韩av在线网页| 亚洲美女www午夜| 欧美夫妻性视频| 91在线中文字幕| 亚洲欧美国产精品久久久久久久| 亚洲色图18p| 日韩国产欧美精品一区二区三区| 欧美人与性动交| www.国产一区| 亚洲一区二区免费| 精品亚洲va在线va天堂资源站| 中文字幕不卡在线视频极品| 欧美丝袜美女中出在线| 亚洲国产精彩中文乱码av在线播放| 欧美大尺度电影在线观看| 国产精品一区二区三区成人| 一区二区三区 在线观看视| 中文字幕亚洲一区二区三区| 欧美一区三区三区高中清蜜桃| 久久大大胆人体| 国产亚洲一级高清| 欧美成人激情在线| 日韩中文在线中文网三级| 欧美亚洲国产日韩2020| 中文字幕亚洲欧美日韩2019| 久久影院资源站| 亚洲第一中文字幕| 亚洲美女性生活视频| 亚洲激情久久久| 国产一区私人高清影院| 国产欧美日韩最新| 欧美日韩一二三四五区| 日韩av电影院| 亚洲欧美日韩图片| 日韩小视频在线| 97超级碰碰碰| 欧美极品第一页| 国产精品草莓在线免费观看| 成人在线视频网站| 68精品国产免费久久久久久婷婷| 亚州国产精品久久久| 97精品在线视频| 欧美极品少妇xxxxⅹ裸体艺术| 奇米成人av国产一区二区三区| 色综合久久88色综合天天看泰| 久久中文字幕在线视频| 国产女同一区二区| 国产精品www网站| 91tv亚洲精品香蕉国产一区7ujn| 欧美精品性视频| 国产亚洲精品高潮| 久久久亚洲影院你懂的| 国产精品白丝av嫩草影院| 精品成人国产在线观看男人呻吟| 日韩中文字幕精品视频| 亚洲国产毛片完整版| 亚洲美女精品成人在线视频| 欧美色道久久88综合亚洲精品| 久久久久久美女| 欧美一级淫片aaaaaaa视频| 黑人狂躁日本妞一区二区三区| 久久久久久久久久国产| 欧美日韩国产精品专区| 国产精品中文在线| 日本亚洲欧美成人| 国产精品久久久久91| 美女av一区二区三区| 韩剧1988在线观看免费完整版| 91精品免费视频| 亚洲区bt下载| 91麻豆国产语对白在线观看| 色综合五月天导航| 国产一区二区色| 在线观看欧美视频| 久久69精品久久久久久久电影好| 日韩国产中文字幕| 91天堂在线观看| 国产精品久久久久久久久影视| 久久午夜a级毛片| 777国产偷窥盗摄精品视频| 俺也去精品视频在线观看| 97精品视频在线| 亚洲成人a级网| 亚洲国产精品一区二区三区| 日韩在线不卡视频| 国产精品久久久久久久一区探花| 伊人久久久久久久久久久久久| 91精品久久久久久久久久久久久久| 一区二区三区动漫| 亚洲xxxx做受欧美| 黑人极品videos精品欧美裸| www.午夜精品| 九九热精品视频| 亚洲精品视频久久| 一区二区欧美亚洲| 国产在线拍揄自揄视频不卡99| 欧美裸身视频免费观看| 国产精品精品久久久久久| 亚洲精品国产suv| 日韩免费观看网站| 国产小视频国产精品| 欧美精品videossex性护士| 日韩av在线资源| 日韩电影中文字幕在线观看| 欧美老女人www| 国语对白做受69| 18久久久久久| 亚洲免费中文字幕| 久久亚洲私人国产精品va| 不用播放器成人网| 97在线视频免费| 欧美日韩在线一区| 国产成人拍精品视频午夜网站| 2019中文字幕在线观看| 日韩av黄色在线观看| 日产日韩在线亚洲欧美| 韩剧1988在线观看免费完整版| 亚洲图片在线综合| 成人激情免费在线| 午夜精品在线观看| 热99久久精品| 欧美日韩在线第一页| 国产精品色悠悠| 日韩av观看网址| 91成品人片a无限观看| 91在线观看欧美日韩| 美女啪啪无遮挡免费久久网站| 久久99视频精品| 欧美成aaa人片在线观看蜜臀| 不卡av在线网站| 欧美激情网友自拍| 欧美性xxxxx极品| 久久夜色精品国产| 精品丝袜一区二区三区| 久精品免费视频| 色哟哟亚洲精品一区二区| 亚洲人成网站免费播放| 国产性猛交xxxx免费看久久| 日韩有码在线视频|