- 1、本文档共97页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数据库访问的其他技术 ADO和OLEDB之间的关系 OLEDB是一种底层数据访问界面接口 用于第三方驱动程序商家开发输出数据源到ADO-技术的应用程序或用于C++的开发者开发定制的数据库组件。 OLE DB 是用于访问数据的重要的系统级编程接口,它是 ADO 的基础技术,同时还是 ADO.NET 的数据源。 ADO 是基于OLE DB的访问接口,它是面向对象的OLE DB技术,继承了OLE DB的优点。ADO为OLEDB提供高层应用API函数。 下章再见 SQL/CLI的应用 API是微软公司ODBC技术的术语,是非SQL名称。 在SQL标准中,称为“调用层接口”(Call Level Interface,简记为CLI)。 SQL/CLI是ODBC技术的延续。 下面介绍SQL/CLI的使用,用C语言作为宿主语言。CLI定义了一套可以从宿主语言调用的公共函数,每一个函数具有一个名称和一个要求的算法(当使用这个函数调用时,DBMS应该做什么)。在SQL3的第三部分介绍了SQL/CLI。 SQL/CLI的应用 使用SQL/CLI时,有必要将宿主程序与数据库交互的有关信息记录在运行时数据结果中。此信息保存在以下四种类型的记录中,表示为C数据类型中的复合结构(Struct): ●环境记录(Environment Record):用作为一个容器,设置环境信息,以保存一个或多个数据库连接。 ●连接记录(Connection Record):保存一个特定数据库连接所需的信息,表示应用系统与数据源之间的连接。 ●语句记录(Statement Record):保存一个SQL语句所需的信息。 ●描述记录(Description Record):保存元组或参数的有关信息,如元组中的属性个数及其类型,或某个函数调用中的参数个数及其类型。 SQL/CLI的应用 若要创建记录,需要使用如下SQL/CLI函数: SQLAllocHandle(handle_type,handle_1, handle_2) 函数中参数的含义如下: handle_type指示所创建记录的类型。此参数可能的 值为关键字SQL_HANDLE_ENV、 SQL_HANDLE_DBC、SQL_HANDLE_STMT、 SQL_HANDLE_DESC。 handle_1指示了新句柄在哪个容器中创建。 handle_2是指向新创建的handle_type类型记录的 指针(句柄)。 SQL/CLI的应用 例10.3 下面的程序段是读取(输入)某学生的学号,然后查询关系S,并打印该学生的姓名和年龄。 0)#include sqlcli.h; 1)void printAge(){ 2)SQLHSTMT stmt1; 3)SQLHDBC con1; 4)SQLHENV env1; 5)SQLRETURN ret1,ret2,ret3,ret4; 6)ret1=SQLAllocHandle(SQL_HANDLE_ENV, SQL_NULL_HANDLE,env1); 7)if(!ret1) ret2=SQLAllocHandle( SQL_HANDLE_DBC,env1,con1) else exit; SQL/CLI的应用 8)if(!ret2) ret3=SQLConnect(con1,〞dbs〞, SQL_NTS,〞js〞,SQL_NTS, 〞xyz〞,SQL_NTS) else exit; 9)if(!ret3) ret4=SQLAllocHandle( SQL_HANDLE_STMT,con1,stmt1) else exit; 10)SQLPrepare(stmt1,〞select SNAME,AGE from S where S#=?〞,SQL_NTS); 11)prompt(〞Enter a Student Number:〞,s#); 12)SQLBindParameter(stmt1,1,SQL_CHAR,s#,5, fetchlen1); 13)ret1=SQLExecute(stmt1); SQL/CLI的应用 14)if(!ret1){ 15) SQLBindCol(stmt1,1,SQL_CHAR,sname, 9,fetchlen1); 16) SQLBindCol(stmt1,2,SQL_SMALLINT,age, 2,fetchlen2); 17) ret2=SQLFetch(stmt1); 18) if(!ret2) printf(s#,sname,age); 19
您可能关注的文档
- 立体几何大题介绍.doc
- 价格变动的影响(最新)资料.ppt
- 励磁系统调试介绍.doc
- 弱电工程实习介绍.doc
- 价格鉴定案例1资料.ppt
- 价值观-整理版资料.ppt
- 弱电施工安全保护措施方案介绍.doc
- 三、酸再生工艺技术规程介绍.doc
- 三个儿子教学实录及反思介绍.doc
- 三国演义练习介绍.doc
- 白天晚上教学课件.ppt
- 2025年山东菏泽市牡丹区中医医院引进急需紧缺专业技术人才30人笔试模拟试题参考答案详解.docx
- 2025年山东菏泽市牡丹区中医医院引进急需紧缺专业技术人才30人笔试模拟试题带答案详解.docx
- 2025年山东菏泽市牡丹区中医医院引进急需紧缺专业技术人才30人笔试模拟试题及参考答案详解.docx
- 2025年山东菏泽市牡丹区中医医院引进急需紧缺专业技术人才30人笔试模拟试题及参考答案详解一套.docx
- 2025年山东菏泽市牡丹区中医医院引进急需紧缺专业技术人才30人笔试模拟试题及完整答案详解1套.docx
- 2025年山东菏泽市牡丹区中医医院引进急需紧缺专业技术人才30人笔试模拟试题及参考答案详解1套.docx
- 2025年山东菏泽市事业单位招聘急需紧缺岗位目录(第一批)笔试模拟试题参考答案详解.docx
- 2025年山东菏泽市牡丹区中医医院引进急需紧缺专业技术人才30人笔试模拟试题及答案详解1套.docx
- 画西瓜教学课件.ppt
文档评论(0)