六月婷婷综合激情-六月婷婷综合-六月婷婷在线观看-六月婷婷在线-亚洲黄色在线网站-亚洲黄色在线观看网站

明輝手游網(wǎng)中心:是一個免費提供流行視頻軟件教程、在線學(xué)習(xí)分享的學(xué)習(xí)平臺!

利 用 ISAPI 實 現(xiàn) 向 數(shù) 據(jù) 庫 中 添 加 記 錄 (4)

[摘要]4、ISAPI 應(yīng) 用 程 序 的 編 寫    我 們 利 用 SQL 語 句 可 嵌 入 在 應(yīng) 用 程 序 中 的 特 點, 把 SQL 的 有 關(guān) 請 求 語 句 嵌 入 在 ISAPI 交 互 程 序 中。 ISAPI 交 互 程 序 用 Visual C...
4、ISAPI 應(yīng) 用 程 序 的 編 寫

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

  
   // 建 立 一 個 CZY 類 的 成 員 函 數(shù) FileWrite1Entry, 實 現(xiàn) 向 中 藥 數(shù) 據(jù) 庫 的 表 CMT1 中 添 加 記 錄
void CZY::FileWrite1Entry(CHttpServerContext* pCtxt, LPTSTR pstrFileName)
{
    const unsigned REC_NUM=1;    // REC_NUM(數(shù)據(jù)文件中記錄個數(shù))
    const unsigned LINE=9;        // LINE(表中數(shù)據(jù)域的個數(shù))
    const unsigned COLUMN=6000;    // COLUMN(每個數(shù)據(jù)域中字符的最大個數(shù))
    char c,data[LINE][COLUMN];
    FILE *fp;
    StartContent(pCtxt);        //HTML頭格式
    WriteTitle(pCtxt);            //HTML標(biāo)題
    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;
    }
    //從文件中讀取數(shù)據(jù)
    for(int k=0; k< REC_NUM; k++)
    {
        for(int I=0; I< LINE; I++)
        {
            //忽略"{"以前的說明性字符
            do{
                c=getc(fp);
            }while(c!='{');
            //讀取"{"和"}"之間的字符數(shù)據(jù)
            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)
    //把從文件中讀取的數(shù)據(jù)賦給相應(yīng)的字符型變量
    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];
    //創(chuàng)建數(shù)據(jù)庫對象
    Cdatabase db;
    // 確認(rèn)數(shù)據(jù)
    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);
    // 打開數(shù)據(jù)庫對象,如果此對象不存在就退出
    if(!db.Open(ZyDB, //lpszDSN
        FALSE, //bExclusive
        FALSE, //bReadOnly
        CONNECTSTRING, //lpszConnect
        FALSE)) //bUseCursorLib
    {
        *pCtxt < < "Could not open the database.";
        return;
    }
    //創(chuàng)建RECOREDSET類的數(shù)據(jù)庫表對象
    CZyCMT1 rsZy(&db);
    //指定格式化的添加記錄的條件給表對象
    rsZy.m_strFilter = strQuery;
    //打開表對象,如果不能打開就CATCH異常處理
    try
    {
        if(rsZy.Open(Crecordset::dynaset))
        {
            //如果想添加的記錄已經(jīng)存在于數(shù)據(jù)庫的表中,就給出IDS_ONFILE中包含的反饋信息
            if(!rsZy.IsBOF())
            {
                strOutput.Format(IDS_ONFILE, pstrZY00, SCRIPTPATH);
            }
            else
            {
                // 構(gòu)造插入記錄語句
                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);
                //執(zhí)行插入記錄命令。如果成功給出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
            //如果數(shù)據(jù)庫表對象不能打開,給出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();        //關(guān)閉表對象
    db.Close();        //關(guān)閉數(shù)據(jù)庫
    //給用戶顯示反饋的信息
    *pCtxt < < strOutput;
    EndContent(pCtxt);    //HTML尾格式
}


  

   編 譯 好 的 ISAPI 動 態(tài) 連 接 庫 程 序 將 其 置 于 /Scripts 目 錄 中。 /Scripts 是 交 互 程 序 的 虛 擬 目 錄。 它 可 通 過 WWW 服 務(wù) 管 理 器 來 設(shè) 定。 當(dāng) WWW 第 一 次 被 安 裝 時, 缺 省 的 ISAPI 可 執(zhí) 行 的 虛 擬 目 錄 是 /Scripts。


主站蜘蛛池模板: 亚洲第一黄网站 | 性生免费视频 | 日本免费看片在线播放 | 日本高清视频色wwwwww色 | 日本视频播放免费线上观看 | 午夜免费啪在线观看视频网站 | 一级做a爰片久久毛片毛片 一级做a爰片久久毛片看看 | 日韩一级片免费观看 | 手机看片福利日韩 | 日本乱码一卡二卡三卡永久 | 天天影视色香欲综合免费 | 一二三四在线观看高清在线观看一 | 四虎国产精品视频免费看 | 日干夜操 | 日韩成人邪恶影片 | 色婷婷天天综合在线 | 一二三四在线观看高清在线观看一 | 日本精高清区一 | 亚洲国产天堂在线观看 | 欧美影院在线观看在线观看看 | 四虎影院永久网址 | 中国女人一级做受免费视频 | 日本动态120秒免费 日本叼嗨 | 婷婷性 | 色婷婷丁香 | 色天天天天 | 天天干在线播放 | 日韩欧美成人乱码一在线 | 热久久伊人 | 欧美在线a级高清 | 欧洲成品大片在线播放 | 亚洲人成网站看在线播放 | 天天操天天干天天操 | 色狠狠狠色噜噜噜综合网 | 日本草草影院 | 香港三日本三级人妇三级99 | 日韩伦理一区二区 | 日韩欧美视频二区 | 四虎在线影视在线影库 | 小小小小视频高清日本 | 欧美一区二区三区大片 |