ODBC 安装/使用/编程

ODBC 安装/使用/编程前言:主要讲解ODBCAPI,以mysql为例,从配置到安装,再到具体的编程,以期对ODBC有个初步的认识.*)下载mysql,选择社区版mysql,并安装http://dev.m

大家好,又见面了,我是你们的朋友全栈君。

 前言:

  主要讲解ODBC API, 以mysql为例, 从配置到安装, 再到具体的编程, 以期对ODBC有个初步的认识.

*) 下载mysql, 选择社区版mysql, 并安装
  http://dev.mysql.com/downloads/mysql/

*) 下载mysql-odbc driver驱动, 记得要下载32版本
  http://dev.mysql.com/downloads/connector/odbc/

*) 使用odbc数据源管理器, 推荐odbcad32.exe
  http://support.microsoft.com/kb/942976/zh-cn

*) 驱动在注册表
  在注册表目录项HKEY_LOCAL_MACHINE\SOFTWARE\ODBC\ODBCINST.INI下, 就能看到Mysql ODBC 驱动具体细节了. 目录项ODBC Drivers保存着系统中已安装的所有ODBC驱动信息.目录项Mysql ODBC 5.3 Unicode Driver则保存着具体的mysql驱动信息.
  键Driver和键Setup的区别在哪? Driver对应的dll, 是具体实现的ODBC Driver, 而Setup对应的dll, 只是应用于系统的ODBC驱动管理器(odbc.exe, odbcad32.exe), 用于配置DNS数据源. 而对于32位的驱动, 其对应的注册表目录项在HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\ODBC\ODBCINST.INI下, 这也是个差异点.

<span role="heading" aria-level="2">ODBC 安装/使用/编程

*) 在用户/系统DSN中, 添加DSN, 选择mysql-odbc, 如图所示:
<span role="heading" aria-level="2">ODBC 安装/使用/编程
  编辑DSN如图所示:
<span role="heading" aria-level="2">ODBC 安装/使用/编程

  在windows注册表目录项HKEY_CURRENT_USER\SOFTWARE\ODBC\ODBC.INI下, 为具体的创建的DSN.

<span role="heading" aria-level="2">ODBC 安装/使用/编程

  数据源mysql_test为之前创建, 具体记录了详细的配置信息, 其中Driver具体对应 C:\Program Files (x86)\MySQL\Connector ODBC 5.3\myodbc5w.dll, database对应数据库test. 每个数据源其具体项各有区别. ODBC Data sources目录项, 记录了其他所有的数据源项, 方便告知驱动程序管理器具体odbc驱动器的数据源类型.
<span role="heading" aria-level="2">ODBC 安装/使用/编程
  用户DSN和系统DSN之间的区别, 用户DSN只对当前用户有效, 其所在的注册表的位置信息一般在HKEY_CURRENT_USER\SOFTWARE\ODBC\ODBC.INI目录项下, 而系统DSN对所有用户都有效, 在HKEY_LOCAL_MACHINE\SOFTWARE\ODBC\ODBC.INI目录项下.

*) 在数据库test下, 创建

<span role="heading" aria-level="2">ODBC 安装/使用/编程

*)odbc-api例子
  http://wenku.baidu.com/link?url=Reerd4fWwMOoSLW1gmCQgluaMFEMUBq1Wq-o6e3Iu13UbZaaqKYpwNPnX0Ik_rXEBvhTNg380GhMZBJxfv65K0f3410SlF-5wWd3LLuwTE7
  http://wenku.baidu.com/view/7cefbf1ec5da50e2524d7fbc.html

  编译器出现如下错误时:
  出现错误error C2146: syntax error : missing ‘;’ before identifier ‘SQLHWND’
  需要在包含sql.h, sqlext.h头文件之前包含windows.h
  参考如下解决方案: http://bbs.csdn.net/topics/60260260

  出现错误: cannot convert parameter 2 from ‘SQLCHAR *’ to ‘SQLWCHAR *’
  参考如下解决方案: http://blog.sina.com.cn/s/blog_6d2a0a1a01019k9r.html

/*
*	
*	for example:
*		odbc example
*
*
*	本例子的目的: 通过odbc编程, 来对odbc的接口有个感性而深入的认识
*
*
*/

#include <stdio.h>

#include <assert.h>

#include <windows.h> 
#include <sql.h>
#include <sqlext.h>

int main()
{

	HENV henv;

	// *) 申请环境句柄
	SQLRETURN rcode = SQLAllocHandle(SQL_HANDLE_ENV, SQL_NULL_HANDLE, &henv);
	assert(!(rcode != SQL_SUCCESS && rcode != SQL_SUCCESS_WITH_INFO));

	// *) 设置ODBC版本的环境属性 
	rcode = SQLSetEnvAttr(henv, SQL_ATTR_ODBC_VERSION, (void *)SQL_OV_ODBC3, 0); 
	assert(!(rcode != SQL_SUCCESS && rcode != SQL_SUCCESS_WITH_INFO));

	// *) 分配连接句柄
	SQLHDBC hdbc;
	rcode = SQLAllocHandle(SQL_HANDLE_DBC, henv, &hdbc); 
	assert(!(rcode != SQL_SUCCESS && rcode != SQL_SUCCESS_WITH_INFO));

	// *) 连接数据源
	rcode = SQLConnect(hdbc, (SQLCHAR *)"mysql_test", SQL_NTS, 
		(SQLCHAR *)"root", SQL_NTS, (SQLCHAR *)"123456", SQL_NTS); 
	assert(!(rcode != SQL_SUCCESS && rcode != SQL_SUCCESS_WITH_INFO));

	// *) 创建SQL语句句柄
	SQLHSTMT stmt;
	rcode = SQLAllocHandle(SQL_HANDLE_STMT, hdbc,&stmt);
	assert(!(rcode != SQL_SUCCESS && rcode != SQL_SUCCESS_WITH_INFO));

	// *) 执行具体的sql
	rcode = SQLExecDirect(stmt, (SQLCHAR*)"select * from tb_student", SQL_NTS);
	assert(!(rcode != SQL_SUCCESS && rcode != SQL_SUCCESS_WITH_INFO));

	// *) 绑定和获取具体的数据项 
	SQLINTEGER res = SQL_NTS;
	SQLCHAR name[128];
	SQLINTEGER age;
	SQLBindCol(stmt, 2, SQL_C_CHAR, name, sizeof(name), &res);
	SQLBindCol(stmt, 3, SQL_C_SLONG, &age, sizeof(age), &res);

	while ((rcode=SQLFetch(stmt))!=SQL_NO_DATA_FOUND) {
		if( rcode == SQL_ERROR) {
			printf("sql error!\n");
		} else {
			printf("name:%s, age:%ld\n",name, age);
		}
	}

	// *) 清理工作, 释放具体的资源句柄
	SQLFreeHandle(SQL_HANDLE_STMT, stmt);
	SQLDisconnect(hdbc);
	SQLFreeHandle(SQL_HANDLE_DBC, hdbc);
	SQLFreeHandle(SQL_HANDLE_ENV, henv);

	return 0;

} 

  附带ODBC的数据类型转换列表

C语言数据类型名称

ODBC 数据类型定义

C语言实际类型

SQL_C_CHAR

SQLCHAR *

unsigned char *

SQL_C_SSHORT[j]

SQLSMALLINT

short int

SQL_C_USHORT[j]

SQLUSMALLINT

unsigned short int

SQL_C_SLONG[j]

SQLINTEGER

long int

SQL_C_ULONG[j]

SQLUINTEGER

unsigned long int

SQL_C_FLOAT

SQLREAL

float

SQL_C_DOUBLE

SQLDOUBLE, SQLFLOAT

double

SQL_C_BIT

SQLCHAR

unsigned char

SQL_C_STINYINT[j]

SQLSCHAR

signed char

SQL_C_UTINYINT[j]

SQLCHAR

unsigned char

SQL_C_SBIGINT

SQLBIGINT

_int64[h]

SQL_C_UBIGINT

SQLUBIGINT

unsigned _int64[h]

SQL_C_BINARY

SQLCHAR *

unsigned char *

SQL_C_BOOKMARK[i]

BOOKMARK

unsigned long int[d]

SQL_C_VARBOOKMARK

SQLCHAR *

unsigned char *

SQL_C_TYPE_DATE[c]

SQL_DATE_STRUCT

struct tagDATE_STRUCT {
     SQLSMALLINT year; 
     SQLUSMALLINT month; 
     SQLUSMALLINT day; 
} DATE_STRUCT;[a]

SQL_C_TYPE_TIME[c]

SQL_TIME_STRUCT

struct tagTIME_STRUCT {
     SQLUSMALLINT hour; 
     SQLUSMALLINT minute; 
     SQLUSMALLINT second; 
} TIME_STRUCT;[a]

SQL_C_TYPE_TIMESTAMP[c]

SQL_TIMESTAMP_STRUCT

struct tagTIMESTAMP_STRUCT {
     SQLSMALLINT year; 
     SQLUSMALLINT month; 
     SQLUSMALLINT day; 
     SQLUSMALLINT hour; 
     SQLUSMALLINT minute; 
     SQLUSMALLINT second; 
     SQLUINTEGER fraction;[b]
} TIMESTAMP_STRUCT;[a]

SQL_C_NUMERIC

SQL_NUMERIC_STRUCT

struct tagSQL_NUMERIC_STRUCT {
     SQLCHAR precision;
     SQLSCHAR scale; 
     SQLCHAR sign[g]
     SQLCHAR val[SQL_MAX_NUMERIC_LEN];[e], [f]
} SQL_NUMERIC_STRUCT;

SQL_C_GUID

SQLGUID

struct tagSQLGUID {
DWORD Data1;
WORD Data2;
WORD Data3;
BYTE Data4[8];
} SQLGUID;[k]

 

 
 
 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/154512.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 【Linux】vim的复制粘贴

    【Linux】vim的复制粘贴vim复制粘贴1.选定文本块。使用v进入可视模式,移动光标键选定内容。2.复制的命令是y,即yank(提起),常用的命令如下:y在使用v模式选定了某一块的时候,复制选定块到缓冲区用;yy复制整行(nyy或者yny,复制n行,n为数字);y^复制当前到行头的内容;y$复制当前到行尾的内容;yw复制一个word(nyw或者ynw,复制n个word,n为数字);yG复制至档尾(nyG或者ynG,复制到第n行,例如1yG或者y1G,复制到档尾)

    2022年9月16日
    2
  • gtest的介绍和使用

    gtest的介绍和使用一、什仫是gtestgtest是一个跨平台的(Liunx、MacOSX、Windows、Cygwin、WindowsCEandSymbian)C++单元测试框架,由google公司发布。gtest是为在不同平台上为编写C++测试而生成的。它提供了丰富的断言、致命和非致命判断、参数化、”死亡测试”等等。了解了什仫是gtest之后下面让我们来学习gt…

    2022年9月29日
    3
  • 摄像头模组 PDAF对焦(Phase Detection Auto Focus)

    摄像头模组 PDAF对焦(Phase Detection Auto Focus)http://blog.csdn.net/sylorchen/article/details/54618912本文主要是最近看的两个文档的总结,相对零散的笔记,包括《imx298softwarereferencePDAF》与《PDAFTruly》。1、PDAF功能的实现需要使用到shieldpixel的概念,包括right-half-shield与left-half-

    2025年9月25日
    4
  • python 脚本实现查看文件内容

    python 脚本实现查看文件内容

    2022年4月2日
    61
  • python识别文字位置_如何利用Python识别图片中的文字

    python识别文字位置_如何利用Python识别图片中的文字一、前言不知道大家有没有遇到过这样的问题,就是在某个软件或者某个网页里面有一篇文章,你非常喜欢,但是不能复制。或者像百度文档一样,只能复制一部分,这个时候我们就会选择截图保存。但是当我们想用到里面的文字时,还是要一个字一个字打出来。那么我们能不能直接识别图片中的文字呢?答案是肯定的。二、Tesseract文字识别是ORC的一部分内容,ORC的意思是光学字符识别,通俗讲就是文字识别。Tesserac…

    2022年5月18日
    59
  • Google资深工程师深度讲解Go语言–面向接口(五)[通俗易懂]

    Google资深工程师深度讲解Go语言–面向接口(五)

    2022年2月15日
    43

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号