利用ISAPI实现向数据库中添加记录

2024-03-11 09:48
文章标签 实现 记录 数据库 isapi

本文主要是介绍利用ISAPI实现向数据库中添加记录,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

      本 文 介 绍 了 用 HTML(Hypertext Makeup Language) 编 写 界 面、 编 写 ISAPI(Internet Server Application Programming Interface) 交 互 程 序 以 实 现 向 用 Microsoft SQL Server 建 立 的 数 据 库 中 添 加 记 录 的 方 法。

   1、 前 言

   Microsoft SQL Server 是 一 种 可 伸 缩 的、 高 性 能 的 关 系 型 数 据 库 管 理 系 统(RDBMS), 它 专 为 分 布 式 客 户 机 - 服 务 器 计 算 环 境 而 设 计。 它 的 内 置 数 据 复 制 功 能、 强 大 的 管 理 工 具 和 开 放 式 的 系 统 体 系 结 构 为 发 布 信 息 提 供 了 一 个 卓 越 的 平 台。 它 的 内 置 数 据 复 制 功 能 为 在 整 个 组 织 机 构 内 分 发 准 确 的 信 息 提 供 了 一 个 强 大 且 可 靠 的 方 式, 库 中 的 数 据 不 仅 可 以 复 制 给 Microsoft SQL Server 数 据 库, 也 可 以 复 制 给 ORACLE、 IBM DB2、 SYBASE 和 其 它 数 据 库。

   Microsoft SQL Server 为 用 户 提 供 的 内 置 数 据 复 制 功 能 - - 块 拷 贝 程 序(bcp) 可 在 数 据 库 管 理 系 统 之 间 迁 移 数 据, 能 将 数 据 从 文 件 拷 贝 到 SQL Server 中。 这 也 就 是 说 用 户 可 以 利 用 bcp 把 某 一 个 文 件 中 的 数 据 内 容 添 加 到 数 据 库 中。 但 是 bcp 是 一 个 可 执 行 程 序, 必 须 在 命 令 提 示 符(如 DOS) 下 运 行 它, 这 给 Windows 用 户 带 来 了 极 大 的 不 方 便; 另 外 bcp 命 令 有 其 固 有 的 格 式 并 带 有 许 多 参 数, 用 户 难 于 记 忆。 我 们 发 展 了 利 用 ISAPI 实 现 向 数 据 库 中 添 加 记 录 的 方 法。 这 种 方 法 用 HTML 编 写 用 户 输 入 文 件 名 的 界 面, 用 ISAPI 作 交 互 程 序。 在 ISAPI 中 通 过 ODBC(Open Database Connectivity) 与 SQL Server 库 连 接。 用 户 只 需 在 HTML 界 面 中 输 入 文 件 名, 文 件 中 的 数 据 内 容 就 被 方 便 地 添 加 到 指 定 的 表 中。 此 方 法 克 服 了 bcp 命 令 的 缺 点。 本 文 介 绍 了 用 ISAPI 实 现 向 中 药 数 据 库 中 添 加 记 录 的 方 法, 并 给 出 了 数 据 库 表 的 建 立 方 法、 数 据 文 件 的 格 式、 ISAPI 主 要 程 序、 输 入 数 据 文 件 名 界 面 的 HTML 文 件 格 式 等。

2、 数 据 库 表 的 建 立

   结 构 化 查 询 语 言 SQL(Structural Query Language) 是 关 系 数 据 库 系 统 的 一 种 高 级 语 言, 它 是 在 七 十 年 代 末 由 IBM 公 司 的 San Jose 研 究 实 验 室 开 发 的, 现 巳 被 许 多 关 系 型 数 据 库 管 理 系 统 所 采 用, 并 被 美 国 国 家 标 准 局 认 定 为 一 种 工 业 标 准 的 关 系 数 据 库 查 询 语 言。 它 具 有 强 大 的 数 据 维 护 和 查 询 功 能, 是 一 种 可 工 作 在 多 用 户 系 统 上 的 数 据 子 语 言。 它 的 命 令 语 句 类 似 于 英 语 句 子, 用 户 使 用 起 来 十 分 方 便、 易 于 理 解。 以 下 是 用 Microsoft SQL Server 建 立 的 "CMT1" 表 举 例:

  

   CREATE TABLE CMT1

   (

   ZY00 varchar (20) NOT NULL ,

   ZY01 varchar (50) NOT NULL ,

   ZY02 text NULL ,

   ZY03 varchar (80) NOT NULL ,

   ZY04 text NULL ,

   ZY05 varchar (100) NOT NULL ,

   ZY06 varchar (9) NOT NULL ,

   ZY07 varchar (5) NOT NULL ,

   ZY08 varchar (2) NOT NULL

   )

3、数 据 文 件 格 式

   以 下 是 向 中 药 数 据 库 表 CMT1 中 添 加 记 录 的 数 据 文 件 格 式:

   ZY00(中 药 中 文 名):{三 七}

   ZY01(中 药 中 文 名 汉 语 拼 音(大 写)):{SANQI}

   ZY02(中 药 中 文 别 名):{人 参 三 七,田 七,盘 龙 七(四 川),金 不 换(江 西)}

   ZY03(中 药 英 文 名):{Sanchi}

   ZY04(中 药 英 文 别 名):{}

   ZY05(中 药 拉 丁 名):{Radix Notoginseng}

   ZY06(中 药 材 唯 一 码):{MMH35002A}

   ZY07(中 药 大 辞 典 编 码):{00096}

   ZY08(功 效 类 别):{18}

   上 述 数 据 文 件 中, 只 有 "{" 和 "}" 符 号 之 间 的 字 符 被 添 加 到 中 药 数 据 库 表 CMT1 的 相 应 数 据 域 中, "{" 之 前 的 字 符 用 于 给 编 写 数 据 文 件 的 用 户 予 于 提 示, 在 ISAPI 程 序 中 可 实 现 只 取 "{" 和 "}" 之 间 的 字 符, 忽 略 "{" 前 的 提 示 字 符 及 "{" 和 "}" 字 符 等。

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。

5、 输 入 数 据 文 件 名 界 面 的 编 写

   HTML 文 件 是 在 普 通 文 本 中 插 入 HTML 标 识 符, WWW 浏 览 器 通 过 识 别 HTML 文 件 中 的 标 识 符, 按 照 HTML 文 件 中 的 标 识 符 所 指 定 的 格 式 显 示 文 件。 下 面 给 出 向 中 药 数 据 库 表 CMT1 中 添 加 记 录 的 输 入 数 据 文 件 名 界 面 的 HTML 具 体 写 法, 此 文 件 取 名 为 FileWrite1.html。

< html>
< body bgcolor="white">
< center>
< h2>< p>< font color = "#FF0000">加记录到中药表一< /font>< /p>< /h2>
< hr>
< h3>请输入文件名:< /h3>
< form action="/scripts/Zy.dll?FileWrite1Entry" method="post">
< p>< input name= "FileName" size=40>< /p>
< input type="submit" value="提交">
< input type="reset" value="重置">
< /form>
< /center>
< /body>
< /html>


   在 Netscape 或 Internet Explorer 的 URL 中 键 入 http://webserver/FileWrite1.html, 其 中 webserver 是 服 务 器 名 或 服 务 器 的 域 名, 屏 幕 上 就 会 显 示 输 入 数 据 文 件 名 的 界 面, 根 据 界 面 提 示 在 表 栏 中 输 入 数 据 文 件 名, 提 交 后 反 馈 信 息 在 客 户 端 的 显 示

6、 结 论

    

       我 们 发 展 的 利 用 ISAPI 向 数 据 库 中 添 加 记 录 的 方 法
    不 需 要 在 DOS 提 示 符 下 进 行 任 何 操 作。 另 外, 我 们 的 数
    据 文 件 中 可 包 含 为 编 写 数 据 文 件 的 用 户 加 入 的 提 示
    字 符, 提 示 字 符 并 不 会 加 入 到 数 据 库 中, 而 Microsoft SQL
    Server 的 bcp 命 令 无 法 选 定 忽 略 数 据 文 件 中 的 任 何 字 符,
    只 能 把 数 据 文 件 中 的 所 有 数 据 拷 贝 到 数 据 库 中。 同
    时, 后 者 需 在 DOS 提 示 符 下 操 作。

    

       利 用 ISAPI 作 交 互 程 序 不 仅 可 实 现 网 络 数 据 库 查
    询, 而 且 可 对 数 据 库 中 的 记 录 进 行 操 作(添 加、 修 改、
    删 除 等)。 随 着 Windows NT 使 用 的 普 及, ISAPI 的 应 用 范 围 将
    会 越 来 越 广 泛。

这篇关于利用ISAPI实现向数据库中添加记录的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/797453

相关文章

C++使用栈实现括号匹配的代码详解

《C++使用栈实现括号匹配的代码详解》在编程中,括号匹配是一个常见问题,尤其是在处理数学表达式、编译器解析等任务时,栈是一种非常适合处理此类问题的数据结构,能够精确地管理括号的匹配问题,本文将通过C+... 目录引言问题描述代码讲解代码解析栈的状态表示测试总结引言在编程中,括号匹配是一个常见问题,尤其是在

Python调用Orator ORM进行数据库操作

《Python调用OratorORM进行数据库操作》OratorORM是一个功能丰富且灵活的PythonORM库,旨在简化数据库操作,它支持多种数据库并提供了简洁且直观的API,下面我们就... 目录Orator ORM 主要特点安装使用示例总结Orator ORM 是一个功能丰富且灵活的 python O

Java实现检查多个时间段是否有重合

《Java实现检查多个时间段是否有重合》这篇文章主要为大家详细介绍了如何使用Java实现检查多个时间段是否有重合,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录流程概述步骤详解China编程步骤1:定义时间段类步骤2:添加时间段步骤3:检查时间段是否有重合步骤4:输出结果示例代码结语作

使用C++实现链表元素的反转

《使用C++实现链表元素的反转》反转链表是链表操作中一个经典的问题,也是面试中常见的考题,本文将从思路到实现一步步地讲解如何实现链表的反转,帮助初学者理解这一操作,我们将使用C++代码演示具体实现,同... 目录问题定义思路分析代码实现带头节点的链表代码讲解其他实现方式时间和空间复杂度分析总结问题定义给定

Java覆盖第三方jar包中的某一个类的实现方法

《Java覆盖第三方jar包中的某一个类的实现方法》在我们日常的开发中,经常需要使用第三方的jar包,有时候我们会发现第三方的jar包中的某一个类有问题,或者我们需要定制化修改其中的逻辑,那么应该如何... 目录一、需求描述二、示例描述三、操作步骤四、验证结果五、实现原理一、需求描述需求描述如下:需要在

如何使用Java实现请求deepseek

《如何使用Java实现请求deepseek》这篇文章主要为大家详细介绍了如何使用Java实现请求deepseek功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1.deepseek的api创建2.Java实现请求deepseek2.1 pom文件2.2 json转化文件2.2

python使用fastapi实现多语言国际化的操作指南

《python使用fastapi实现多语言国际化的操作指南》本文介绍了使用Python和FastAPI实现多语言国际化的操作指南,包括多语言架构技术栈、翻译管理、前端本地化、语言切换机制以及常见陷阱和... 目录多语言国际化实现指南项目多语言架构技术栈目录结构翻译工作流1. 翻译数据存储2. 翻译生成脚本

如何通过Python实现一个消息队列

《如何通过Python实现一个消息队列》这篇文章主要为大家详细介绍了如何通过Python实现一个简单的消息队列,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录如何通过 python 实现消息队列如何把 http 请求放在队列中执行1. 使用 queue.Queue 和 reque

Python如何实现PDF隐私信息检测

《Python如何实现PDF隐私信息检测》随着越来越多的个人信息以电子形式存储和传输,确保这些信息的安全至关重要,本文将介绍如何使用Python检测PDF文件中的隐私信息,需要的可以参考下... 目录项目背景技术栈代码解析功能说明运行结php果在当今,数据隐私保护变得尤为重要。随着越来越多的个人信息以电子形

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景