ImageVerifierCode 换一换
格式:DOCX , 页数:15 ,大小:347.83KB ,
资源ID:4381658      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/4381658.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(2设置ODBC数据源.docx)为本站会员(b****4)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

2设置ODBC数据源.docx

1、2设置ODBC数据源目录数据源介绍 2ODBC的标准 2ODBC的体系结构 2ODBC驱动程序 3使用管理器设置ODBC数据源 5通过管理器设置ACCESS数据源 7通过管理器设置SQL Server数据源 8动态加载数据源 9通过修改注册表加载数据源 9通过ODBC API 加载数据源 12特殊数据源的连接方式 13文件数据源的简介及应用 13远程数据库连接 15为了使ODBC能与数据库一起工作,必须把数据库注册到ODBC驱动程序管理器。数据源介绍ODBC的工作依赖于数据库制造商提供的驱动程序,使用ODBC API的时候,Windows的ODBC管理程序把数据库访问的请求传递给正确的驱动程序

2、,驱动程序在使用SQL语句指示DBMS完成数据库访问工作。为了使ODBC能与数据库一起工作,必须把数据库注册到ODBC驱动程序管理器,这项工作可以通过定义一个DSN(Data Source Name,数据源名称)来完成。在使用ODBC访问数据库时,必须通过这个注册的DSN。所以一个数据源信息至少应该包括数据库文件名、系统(本地或远程)、文件夹等信息,同时要给数据源命名。用户可以定义以下三种类型的数据源: 用户数据源:作为位于计算机本地的用户数据源而创建的,并且只能被创建这个数据源的用户所使用。 系统数据源:作为属于计算机或系统而不是特定用户的系统数据源而创建的,用户必须有访问权限才能使用。 文

3、件数据源:指定到文件中作为文件数据源而定义的,任何已经正确的安装了驱动程序的用户节课以使用这种数据源。ODBC的标准ODBC定义了一个标准的调用层接口(CLI)。每个支持ODBC的DBMS需要不同的驱动程序,驱动程序实现ODBC API中的函数。当需要改变驱动程序时,应用程序不需要重新编译或者重新链接,只是动态加载新的驱动程序,并调用其中的函数即可。如果要同时访问多个DBMS系统,应用程序可加载多个驱动程序。使用相同的源代码的应用程序访问不同的DBMS,体现了ODBC的数据独立性。ODBC的体系结构ODBC总体结构有4个组件: 应用程序:执行处理并调用ODBC API函数,以提交SQL语句并检

4、索结果 驱动程序管理器(Driver Manager):根据应用程序的需要加载/卸载驱动程序,处理ODBC函数的调用,或把它们传送到驱动程序。 驱动程序:处理ODBC函数调用,提交SQL请求到一个指定的数据源,并把结果返回到应用程序。如果有必要,驱动程序修改一个应用程序请求,以使请求与相关的DBMS支持的语法一致。 数据源:包括用户要访问的数据及其相关的操作系统、DBMS及用于访问DBMS的网络平台。ODBC驱动程序的使用把应用程序从具体的数据库调用中隔离出来,驱动程序管理器针对特定数据库的各个驱动程序进行集中管理,并向应用程序提供统一的标准接口,这就为ODBC的开放性奠定了基础。图:ODBC

5、部件关系ODBC驱动程序ODBC驱动程序是一个用以支持ODBC函数调用的模块(在Windows下通常是一个DLL),每个驱动程序对应于相应的数据库,当应用程序从基于一个数据库系统移植到另一个时,只需要更改应用程序中的、由ODBC管理程序设定的、与相应数据库系统对应的别名即可。ODBC使用层次的方法来管理数据库,在数据库通信结构的每一层,对可能出现依赖数据库产品自身特性的地方,ODBC都引入一个公共接口以解决潜在的不一致性,从而很好的解决了数据库系统应用程序的相对独立性。从结构上分,ODBC分为单束式和多束式两类。1、 单束式驱动程序单束式驱动程序介于应用程序和数据库之间,像中介驱动程序一样,提

6、供一个统一的数据访问方式。当用户进行数据库操作时,应用程序传递一个ODBC函数调用给ODBC驱动程序管理器,由ODBC API判断该调用是由它直接处理并将结果返回,还是送交驱动程序执行并将结果返回。由上可见,单束式驱动程序本身是一个数据库引擎,由它直接可完成对数据库的操作,尽管该数据库可能位于网络的任何地方。2、 多束式驱动程序多束式驱动程序负责在数据库引擎和客户应用程序之间传送命令和数据,它本身并不执行数据处理操作,只是作为网络通信协议的一个界面。前端应用程序提出对数据库处理的请求,该请求转给ODBC驱动程序管理器,驱动程序管理器依据请求的情况,就地完成或传给多束式驱动程序,多束式驱动程序将

7、请求翻译为特定厂家通信接口(例如Oracle的SQLNet)所能理解的形式并交与接口去处理,接口把请求经网络传送给服务器上的数据引擎,服务器处理完后把结果发回数据库通信接口,再依次传回给应用程序。图:多束式驱动程序传送数据的流程图使用管理器设置ODBC数据源ODBC数据源管理器(Administrator)负责安装驱动程序、管理数据源,并帮助程序员跟踪ODBC的函数调用。在ODBC中,应用程序不能直接存取数据库,它必须通过管理器和数据库交换信息。ODBC数据源管理器负责将应用程序的SQL语句及其他信息传递给驱动程序,而驱动程序则负责将运行结果返回应用程序。在Windows 95或者Window

8、s 98下,ODBC数据源管理器通过【控制面板】-【32bitODBC】打开,而在Windows 2000或者Windows XP下,通过【控制面板】-【管理工具】-【数据源(ODBC)】打开,其界面如图:1) 用户数据源DSN:ODBC用户数据源存储了如何与指定数据库提供者连接的信息,只有当前用户可见,而且只能用于当前计算机上。这里的当前计算机是指这个配置只对当前的计算机有效,而不是说只能配置本机上的数据库。他可以配置局域网中另一台计算机上的数据库。2) 系统数据源DSN:ODBC系统数据源存储了如何与指定数据库提供者连接的信息,系统数据源对当前计算机上的所有用户都是可见的,包括NT服务。也

9、就是说在这里配置的数据源,只要是这台计算机的用户都可以访问。3) 文件DSN:ODBC文件数据源允许用户连接数据提供者,文件DSN可以由安装了相同驱动程序的用户共享,这是介于用户DSN和系统DSN之间的一种共享情况。4) 驱动程序:列出了本机上所有安装的数据库驱动程序,里面列举了每个驱动程序的名称、版本、提供商公司、驱动程序文件名以及安装日期。5) 跟踪:ODBC跟踪允许创建调用ODBC的日志,提供给技术人员查看,里面可以设定日志的路径和文件名。技术人员通过这里面的信息可以看到本机上所有的数据库访问的时间、用户以及出错信息等错误情况。也可以通过这个辅助调试应用程序,可以启动Visual Stu

10、dio的分析器,来进行ODBC的跟踪。6) 连接池:连接池允许应用程序重用原来打开的连接句柄,这样可以节省到服务器的往返过程。7) 关于:列出了所有的ODBC的核心文件通过管理器设置ACCESS数据源这里以Access数据库BIBLIO.mdb为对象,介绍如何配置Access数据源,具体步骤如下:打开数据源管理器-在“用户DSN”标签页中单击【添加】按钮-“创建新数据源”-选择“Driver do Microsoft Access(*.mdb)”-“ODBC Microsoft Access安装”,单击【选择】按钮,选择要配置的数据库文件并输入数据原名和说明字符串,单击【确定】按钮就可以了。通

11、过管理器设置SQL Server数据源打开数据源管理器-在“用户DSN”标签页中单击【添加】按钮-“创建新数据源”-选择“SQL Server”-“创建到SQL Server的新数据源”-在“名称”文本框中输入test,描述可以不要,在服务器中选择local(如果是网络数据源,要选择合适的网络服务器),【下一步】-选择“使用用户输入登录ID和密码的SQL Server验证”,分别在“登录ID”、“密码”后输入SQL Server的账号和密码。-“更改默认的数据库为”选项下选中test-一些额外的设置一般默认就可以-弹出“ODBC Microsoft SQL Server安装”对话框,里面显示了

12、前面的所设置的数据源配置信息,如果准确无误,单击【测试数据源】,如果顺利的话就会显示数据源建立成功。-OVER动态加载数据源通过ODBC数据源管理器手工配置ODBC数据源的方法,对于一般用户而言,可能是一件比较空难的工作。而在实际应用中,往往在同一个应用程序中访问不同的数据源,因而采用一般的加载方法就有了无法克服的缺陷。为能在程序中完成这一工作,方便应用程序的使用,下面介绍在Visual C+ 6.0中两种动态加载ODBC系统数据源的方法,即通过程序执行而自动设置好ODBC数据源,无须再人工设置。通过修改注册表加载数据源当用户在控制面板中配置好ODBC数据源后,Windows系统便在注册表中加

13、入了一些子键来存储用户的配置结果。当应用程序需要用到数据源时,Windows便会通知底层接口查阅注册表中该数据源的配置。如果配置的数据源是用户DSN数据源,Windows系统便会修改注册表的HKEY_CURRENT_USERSOFTWAREODBCODBC.INI子键,如果配置的数据源是系统数据源,Windows系统便会修改注册表的HKEY_LOCAL_MACHINESOFTWAREODBCODBC.INI子键。因此,可以在应用程序中使用Windows API中的注册表编辑函数来完成Windows所做的工作,这样就可以达到动态加载数据源的目的。对于不同类型的数据源,注册表的修改也各有不同,但基

14、本上都要修改两个地方。一个是在ODBC.INI子键下建立一个与数据源描述名同名的子键,并在该子键下建立与数据源配置相关的项;另一个是在ODBC.INIODBC Data Sources子键下建立一个新项以便告诉驱动程序管理器ODBC数据源的类型。下面以配置一个Microsoft Access数据源为例给出实现此功能的函数代码,相关工程为CodeCtrlOdbcBOOL CCodeCtrlOdbcDlg:LoadDbSource(CString strSourceName, /数据源代码CString strSourceDb, /数据库存放路径CString strDescription /数据

15、源描述字节) HKEY hKey; DWORD IDisp; /注册数据源名 CString strSubKey = “SOFTWAREODBCODBC.INI” + strSourceName; RegCreateKeyEx(HKEY_CURRENT_USER,strSubKey,0,NULL,REG_OPTION_NON_VOLATILE,KEY_ALL_ACCESS,NULL,&hKey,&IDisp); /注册ODBC驱动程序 CString value1(“C:WINNTSystem32odbcjt32.dll”); RegSetValueEx(hKey,“Driver”,0,REG

16、_SZ,(const unsigned char *)(LPCTSTR)value1),strlen(LPCTSTR)value1+1) ); /注册数据库文件 CString value2 = strSourceDb; RegSetValueEx(hKey,“DBQ”,0,REG_SZ,(const unsigned char *)(LPCTSTR)value2),strlen(LPCTSTR)value2+1); DWORD value3 = (DWORD)25; RegSetValueEx(hKey, “DriverID”, 0, REG_DWORD, (const BYTE *) &v

17、alue3, Sizeof(DWORD); CString value4(“Ms Access”); RegSetValueEx(hKey,“FIL”,0,REG_SZ,(const unsigned char *)(LPCTSTR)value4),Strlen(LPCTSTR)value4)+1); DWORD value5 = (DWORD) 0 ; RegSetValueEx(hKey,“SafeTransactions”,0,REG_DWORD,(const BYTE *)&value5,Sizeof(DWORD); CString value6(“”); RegSetValueEx(

18、hKey,“UID”,0,REG_SZ,(const unsigned char *)(LPCTSTR)value6),Strlen(LPCTSTR)value6)+1); Return TRUE;通过ODBC API 加载数据源Windows系统子目录中的动态链接库Odbcinst.dll提供了一个可以动态的添加、修改和删除数据源的函数SQLConfigDataSource()。由于Visual C+ 6.0的默认库文件中不包含该函数,因此在使用该函数之前需要将odbcinst.h文件包含在工程的头文件中。在工程的Setting属性的Link属性页的Object/library module

19、s编辑框中添加odbc32.lib,同时保证系统目录system32下有文件odbccp32.dll。该函数原型如下:BOOL SQLConfigDataSource(HWND hwndParent, WORD fRequest, LPCSTR lpszDriver, LPCSTR lpszAttributes);hwndParent:父窗口句柄。如果该值为NULL,将不会显示与父窗口相关的对话框。fRequest:表示配置的类型,取值如下: ODBC_ADD_DSN:添加一个新的用户数据源 ODBC_CONFIG_DSN:修改(配置)一个已存在的用户数据源 ODBC_REMOVE_DSN:删

20、除一个已存在的用户数据源 ODBC_ADD_SYS_DSN:添加一个新的系统数据源 ODBC_CONFIG_SYS_DSN:修改(配置)一个已存在系统数据源 ODBC_REMOVE_SYS_DSN:删除一个已存在的系统数据源lpszDriver:用于传递数据库引擎的名字,等同于方法一中的strDbType变量lpszAttributes:是关键字的值以Microsoft Access为例,设置数据源名为BIBLIO,数据源描述为“示例数据源”,那么在需要动态加载数据源的地方加入下列代码即可:SQLConfigDataSource(NULL, ODBC_ADD_SYS_DSN,“Microsof

21、t Access Driver(*.mdb)”,“DSN = BIBLIO0Descirption = 示例数据库”);特殊数据源的连接方式文件数据源的简介及应用ODBC文件数据源允许用户连接数据提供者,文件DSN可以由安装了相同驱动程序的用户共享,这是介于用户DSN和系统DSN之间的一种共享情况。建立文件数据源的好处是连接信息存储在一个实际的文件中。不止一个用户可以访问这个文件。而且,如果需要把Web应用程序从一种Web服务器移植到另一种Web服务器上,只需要移植这个文件即可。除了用ODBC数据源管理器外,还可以通过函数SQLDriverConnect来添加文件数据源,其定义如下:SQLRE

22、TURN SQLDriverConnect( SQLHDBC ConnectionHandle, /连接句柄 SQLHWND WindowHandle, /窗口句柄 SQLCHAR *InConnectionString, /输入的连接字符串 SQLSMALLINT StringLength1, /InConnectionString的长度 SQLCHAR *OutConnectionString, /输出字符串缓冲区的地址 SQLSMALLINT BufferLength, /预设的输出字符串缓冲区大小 SQLSMALLINT *StringLength2Ptr, /返回实际输出字符串缓冲区

23、的大小SQLUSMALLINT DriverCompletion);/可以取SQL_DRIVER_PROMPT、SQL_DRIVER_COMPLETE、SQL_DRIVER_COMPLETE_REQUIREDSQL_DRIVER_NOPROMPT等几个值。调用时连接字符串中带参数SAVEFILE = file_name。如果该连接成功,ODBC驱动程序将在SAVEFILE参数所指向的位置创建带连接参数的文件数据源,与文件数据源进行连接的代码如下:#include#include#include#include#include#include#define MAXBUFLEN 255SQLHEN

24、V henv = SQL_NULL_HENV;SQLHDBC hdbc1 = SQL_NULL_HDBC;Int main() RETCODE retcode; /如果成功,在ODBC默认目录下创建MyFileDSN.dsn文件数据源 SQLCHAR szConnStrInMAXBUFLEN = “SAVEFILE = MyFileDSN; DRIVER = SQL Server; SERVER = MySQL;” “NETWORK = dbmssocn; UID = sa; PWD = MyPassWord;”; SQLCHAR szConnStrOutMAXBUFLEN; SQLSMALL

25、INT cbConnStrOut = 0; /分配环境句柄 retcode = SQLAllocHandle(SQL_HANDLE_ENV,NULL,&henv); /使用ODBC 3.0版本 retcode = SQLSetEnvAttr(henv,SQL_ATTR_ODBC_VERSION,(SQLPOINTER)SQL_OV_ODBC3,SQL_IS_INTEGER); /分配ODBC连接句柄,并且连接数据源 retcode = SQLAllocHandle(SQL_HANDLE_DBC,henv,&hdbc1); retcode = SQLDriverConnect(hdbc1,NUL

26、L,zConnStrIn,SQL_NTS,szConnStrOut,MAXBUFLEN,&cbConnStrOut,SQL_DRIVER_NOPROMPT); /断开连接,用新的连接字符串测试刚刚创建的文件数据源是否成功 SQLDisconnect(hdbc1); strcpy(szConnStrIn,”FILEDSN=MyFileDSN;UID=sa,PWD=MyPassWord;”); retcode = SQLDriverConnect(hdbc1, /Connection handleNULL, /窗口句柄szConnStrIn, /输入字符串SQL_NTS, /Null_termin

27、ated stringszConnStrOut, /输出字符串的地址MAXBUFLEN, /输出字符串的长度&cbConnStrOut, /记录实际输出字符串长度的地址SQL_DRIVER_NOPROMPT); /清理环境 SQLDisconnect(hdbc1); SQLFreeHandle(SQL_HANDLE_DBC,hdbc1); SQLFreeHandle(SQL_HANDLE_ENV,henv); return(0);远程数据库连接远程的一个服务器上运行了SQL Server,只要在访问程序中注册该数据库的一个数据源,访问该远程数据库的方法与本地数据库是一样的。通过SQLConfi

28、gDataSource()函数注册远程数据源。(该函数也可以注册本地数据源,在“ODBC API加载数据源一节中”)CString m_strIP = “166.111.8.238” /定义IPBOOL m_bLocalDB = FALSE; /定义是本地数据源还是远程数据源BOOL CXXXApp:BuildODBC() char *szPredix = “DSN = Sinoname0DESCRIPTION = Sino Sename0Server=”; char *szSuffix = “0ADDRESS=MyServer0NETWORK=dbmssocn0DATABASE=Sinosr

29、ch0”; char *szLocalCfg1024 = “DSN=Sinoname0DESCRIPTION=Sino Sename0” “SERVER=(local)0ADDRESS=MyServer0NETWORK=dbmssocn0” “DATABASE=Sinoname0” char szAttributes1024; if(m_bLocalDB) /访问本地数据源 memcpy(szAttributes,szLocalCfg,1024);else /访问远程数据源 memset(szAttributes,0,1024); memcpy(szAttributes,szPredix,44); memcpy(szAttributes+44,m_strIP,m_strIP.GetLength(); memcpy(szAttributes+44+m_strIP.GetLength(),szSuffix,53);/注册数据源return SQLConfigDataSource(NULL,ODBC_ADD_DSN,“SQL Server”,szAttributes);/注册完成之后就可以按本地数据源一样访问了。

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1