- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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来决
定参数的长度。
您可能关注的文档
最近下载
- 通信技术-使用Cypress需要避免的5个E2E测试错误(图文).pdf VIP
- 2025年小学一年级新生家长会ppt课件(优质ppt).pptx VIP
- 中国信通院2025人工智能高质量数据集建设指南74页.pdf VIP
- 2025-2026学年小学音乐三年级上册(2024)苏少版(2024)教学设计合集.docx
- 新征程,'心'启航——2025年秋学期开学第一课收心班会.pptx VIP
- Unit 1 How can I get there? PartA(说课稿)-2024-2025学年人教PEP版英语六年级上册[001].docx VIP
- 良好农业规范GAP记录表格.pdf VIP
- 2025年工会相关法律法规知识竞赛试题.doc VIP
- 高等土力学李广信22应力和应变.pptx VIP
- 消失模铸造工艺技术的创新与生产实践.pdf VIP
文档评论(0)