LinuxUnix下ODBC的安装、配置与编程_3.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
LinuxUnix下ODBC的安装、配置与编程_3

四、 Linux/Unix下 ODBC的编程: 1、使用 unixODBC提供的 ODBC API进行编程: 在进行编程之前,我们来看一下 ODBC API中的常用数据类型与我们在 C语言中使用的数 据类型的对应关系: 类型标识符 ODBC数据类型 C数据类型 SQL_C_CHAR SQLCHAR * unsigned char * SQL_C_SSHORT SQLSMALLINT short int SQL_C_USHORT SQLUSMALLINT unsigned short int SQL_C_SLONG SQLINTEGER long int SQL_C_FLOAT SQLREAL float SQL_C_DOUBLE SQLDOUBLE, SQLFLOAT double SQL_C_BINARY SQLCHAR * unsigned char * SQL_C_TYPE_DATE SQL_DATE_STRUCT struct tagDATE_STRUCT {SQLSMALLINT year; SQLUSMALLINT month; SQLUSMALLINT day; } DATE_STRUCT; SQL_C_TYPE_TIME SQL_TIME_STRUCT struct tagTIME_STRUCT {SQLUSMALLINT hour; SQLUSMALLINT minute; SQLUSMALLINT second; } TIME_STRUCT; 我们这里使用的数据库名称为 test(DSN),这个 DSN使用的用户名是 root,密码为空,表 的名称是 web,字段情况如下: 字段名数据类型 id integer name char(40) size integer 第一:设定 ODBC环境句柄并设置参数 首先我们需要声明一个 ODBC环境句柄(SQLHENV),它可以用来获得有关的 ODBC环境 信息,我们需要调用 SQLAllocHandle ( SQL_HANDLE_ENV, SQL_NULL_HANDLE, V_OD_Env )来获得这个句柄,V_OD_Env就是要分配的 SQLHENV类型的环境句柄。 分配好句柄之后,你给它需要设定所使用的 ODBC版本,你可以调用 SQLSetEnvAttr ( V_OD_Env, SQL_ATTR_ODBC_VERSION, (void*)SQL_OV_ODBC3, 0 ), SQL_ATTR_ODBC_VERSION是存放你定义的 ODBC版本号的变量,SQL_OV_ODBC3则 说明你的程序使用的是 ODBC 3.0。 第二:设定连接句柄并设置超时参数 我们需要声明一个连接句柄( SQLHDBC),用来存放数据库连接信息的,调用 SQLAllocHandle ( SQL_HANDLE_DBC, V_OD_Env, V_OD_hdbc )获得连接句柄, V_OD_hdbc就是要分配的 SQLHDBC类型的连接句柄。 分配好之后,我们可以调用 SQLSetConnectAttr ( V_OD_hdbc, SQL_LOGIN_TIMEOUT, (SQLPOINTER *)5, 0 )来设定连接超时参数。 第三:连接数据库 调用 SQLConnect ( V_OD_hdbc, (SQLCHAR*) Test, SQL_NTS, (SQLCHAR*) root, SQL_NTS, (SQLCHAR*) , SQL_NTS )连接我前面提到的数据库,需要设定三个参数,就是 数据库名称、用户名和密码(因为我的数据库密码为空,所以这里的密码也为空),后面的 SQL_NTS的位置应该写入这些参数的长度,如果写的是 SQL_NTS就是让 SQLConnect来决 定参数的长度。

文档评论(0)

qwd513620855 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档