📄 odbc-c1.htm
字号:
<html>
<head>
<title>ODBC 编程教程:基础</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
</head>
<body bgcolor="#000000" text="#FFFFFF" link="#FFFFCC" vlink="#FFCCCC" alink="#CCFFCC">
<h1 align="center"><font face="Tahoma" color="#FFFFCC">ODBC 基础</font></h1>
<p align="left"><font face="Tahoma" size="-1">这是使用 win32asm进行数据库编程系列的第一份教程。
在如今的IT界,数据库编程变的越来越重要,所以我们不能再忽视它。但如今有很多种数据库在使用,如果
我们为了实现win32下数据库汇编语言编程而学习各种数据库文件格式,所花时间大概称得上“永恒”。
</font></p>
<p align="left"><font face="Tahoma" size="-1">幸运的是,Microsoft的一项技术使得我们得以摆脱这个
大麻烦。它被称为<b><font color="#FFFFCC">ODBC</font></b>,是<font color="#CCFFCC"><b>开放式数据库互连(Open Database Connectivity)</b></font>的缩写,这是一族API,与Windows API相似。它主要与数据库打交道。就是说,利用ODBC API,你可通过统一界面
和好多各不相同的数据库打交道。</font></p>
<p align="left"><font face="Tahoma" size="-1">ODBC是如何工作的?它的结构式怎样的?在使用ODBC之前,
你应对它的结构有一个清楚的了解。 ODBC有四个组成部分:</font></p>
<ul>
<li><font color="#FFFFCC" face="Tahoma" size="-1"><b>应用程序 (Application,你的程序)</b></font></li>
<li><font color="#FFFFCC" face="Tahoma" size="-1"><b>ODBC 管理器 (ODBC manager)</b></font></li>
<li><font color="#FFFFCC" face="Tahoma" size="-1"><b>ODBC 驱动程序(ODBC Drivers)</b></font></li>
<li><font color="#FFFFCC" face="Tahoma" size="-1"><b>数据源 (Data Sources,数据库)</b></font></li>
</ul>
<p><font face="Tahoma" size="-1">这四个组件的核心是<font color="#FFFFCC"><b>ODBC 管理器</b></font>。 你可把它想象成你的监工。你告诉它你希望他作什么,然后它把你的要求传达给它的工人(ODBC 驱动程序)并完成工作。如果工人有什么想告诉你的,它会与监工(ODBC 管理器)说,由监工传达给你。工人们很明白他们应作什么,因此他们会为你很好的完成工作。</font></p>
<p><font face="Tahoma" size="-1">通过这样的模式,我们并不与数据库驱动程序直接通信。
你只需告诉数据库管理器你想要做什么。而使用恰当的ODBC驱动程序来实现你的目的则是ODBC管理器的事。
每个ODBC 驱动程序对于它所对应的数据库均有足够了解。各部件各司其职,极大的简化了工作量。</font></p>
<p align="center"><font face="Tahoma" size="-1"><b><font color="#FFFFCC">你的程序<----> ODBC管理器<----> ODBC驱动程序 <----> 数据库</font></b></font></p>
<p><font face="Tahoma" size="-1">ODBC管理器由Microsoft提供。看一下你的控制面板。如果你正确地安装了ODBC你会找到<font color="#CCFFCC"><b>ODBC数据源(32位) </b></font>项目。
至于ODBC驱动程序, Microsoft随他们的产品提供了好几种。并且你总可从数据库提供商那里获得新的ODBC 驱动程序。只要简单地安装新的ODBC驱动程序,你的机器就可使用新的它以前不知道的数据库。</font></p>
<p><font face="Tahoma" size="-1">ODBC APIs 使用很简单,但你需要知道一些关于SQL和数据库的知识。例如字段(field),主键(primary key),记录(record),列(column),行(row)等。我须假定你已知道数据库理论的一些基础知识,这样我才能讨论win32下用汇编语言进行ODBC编程的细节问题。正如你所看到的,ODBC 管理器试图在你的程序里隐藏实现的细节。这意味着它必须提供某些基本界面来与你的程序和ODBC驱动程序进行通讯。 由于ODBC驱动程序在某些性能方面存在着差异,因此必须存在一种方法,以使得我们的程序能够知道某个ODBC驱动程序是否支持某一特性。 ODBC定义了被称为<font color="#FFFFCC"><b>Interface Conformance Levels</b></font>的三层服务界面。第三层是核心层。任何ODBC驱动程序都要象在第一层和第二层实现功能一样实现核心层表中的所有特性。从我们的程序的眼光来看, ODBC APIs被分割为这样的三层。如果某个函数被标为核心的,就意味着你可放心使用而不必担心它是否为你正使用的ODBC驱动程序支持。如果它是一个第一层或第二层的函数,你就得确认ODBC驱动程序是否支持,然后再使用。你可通过MSDN获得ODBC APIs的详细资料。</font></p>
<p><font face="Tahoma" size="-1">在编写代码之前你应了解一些ODBC的名词。</font></p>
<ul>
<li><font color="#FFFFCC" face="Tahoma" size="-1"><b>环境(Environment)</b></font><font face="Tahoma" size="-1">.
和字面意思一样,是一个全局文本用来存取数据。如果你熟悉DAO的话,你可把它想象为一个workspace。它包含应用于所有ODBC session的信息,例如一个session的connections句柄。在用ODBC之前你必须从环境中获得这个句柄。</font></li>
<li><font color="#FFFFCC" face="Tahoma" size="-1"><b>连接(Connection)</b></font><font face="Tahoma" size="-1">.
指定ODBC驱动程序和数据源(数据库)。你可以在同一环境中同时连接不同的数据库</font></li>
<li><font color="#FFFFCC" face="Tahoma" size="-1"><b>语句(Statement)</b></font><font face="Tahoma" size="-1">.
ODBC使用SQL作为自己的语言。 因而只要简单的认为语句就是你希望ODBC执行的SQL命令就行了。</font></li>
</ul>
<p><font face="Tahoma" size="-1">以下是使用ODBC编程的一般步骤:</font></p>
<ol>
<li><font face="Tahoma" size="-1">连接数据源</font></li>
<li><font face="Tahoma" size="-1">创建并执行一条或多条SQL语句</font></li>
<li><font face="Tahoma" size="-1">检查结果记录(如果有的话)</font></li>
<li><font face="Tahoma" size="-1">断开数据源</font></li>
</ol>
<p><font face="Tahoma" size="-1">在接下来的教程中我们来学习如何来实现这几步。 </font></p>
<hr>
<p align="center"><font size="-1"><b><font face="Tahoma">[<a href="http://freeshell.org/~michael">Iczelion's
Win32 Assembly Homepage</a>]</font></b></font></p>
<p align="center"><font size="-1"><b><font face="Tahoma">[由<a href="mailto:hw1979@263.net">orochi</a>于2000年8月1日翻译]</font></b></font></p>
</body>
</html>
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -