c语言实现对db2数据库的访问方法分享 (c访问db2数据库)

C语言实现对DB2数据库的访问方法分享

随着各种应用程序的出现,企业需求数据存储和管理的能力越来越重要。DB2数据库是IBM公司开发的一款强大、可扩展的关系数据库管理系统。它被广泛应用于企业级应用程序开发。C语言是一种底层语言,具有强大的控制和内存管理能力,能够很好地支持对数据存储的访问。本文将分享如何使用C语言实现对DB2数据库的访问。

1. 安装DB2客户端软件

为了使用C语言访问DB2数据库,需要先安装DB2客户端软件。该软件可从IBM官网下载。安装完成后,需要配置环境变量以便在C语言程序中调用DB2库函数。

2. 创建DB2数据库

使用DB2客户端软件连接到DB2数据库服务器,选择一个数据库实例。通过SQL语句创建一个新的数据库,在此新数据库中创建一个表格。这里我们以一个学生成绩管理系统为例,创建一个Student表格,包含以下字段:ID、Name、Age、Score1和Score2。

3. 链接到DB2数据库

在C语言程序中链接到DB2数据库,需要使用以下代码片段:

“`

#include

#include

#include

#include

#include

#include

#include

#include

SQLHENV env;

SQLHDBC dbc;

SQLHSTMT stmt;

SQLRETURN ret;

SQLINTEGER id;

SQLCHAR name[30], score1[10], score2[10];

SQLINTEGER age;

SQLCHAR query[100];

int connect_db2_database()

{

ret = SQLAllocHandle(SQL_HANDLE_ENV, SQL_NULL_HANDLE, &env);

ret = SQLSetEnvAttr(env, SQL_ATTR_ODBC_VERSION, (SQLPOINTER)SQL_OV_ODBC3, 0);

ret = SQLAllocHandle(SQL_HANDLE_DBC, env, &dbc);

SQLCHAR dsn[10] = “mydsn”;

SQLCHAR userid[20] = “db2admin”;

SQLCHAR pwd[20] = “db2admin”;

ret = SQLConnect(dbc, dsn, SQL_NTS, userid, SQL_NTS, pwd, SQL_NTS);

if (ret == SQL_SUCCESS)

{

printf(“connect DB2 database success!\n”);

}else{

printf(“connect DB2 database fled!\n”);

}

return ret;

}

“`

在链接DB2数据库后,可以执行SQL语句查询数据库中的数据。在这里介绍两种查询数据库中数据的方法。

4. 查询方法一:使用SQLPrepare准备SQL语句

使用SQLPrepare准备SQL语句,在使用SQLExecute执行SQL语句查询数据库中的数据。以下是示例代码:

“`

ret = SQLAllocHandle(SQL_HANDLE_STMT, dbc, &stmt);

if (ret == SQL_SUCCESS)

{

printf(“SQLAllocHandle success!\n”);

}

SQLCHAR *sql = “select id, name, age, score1, score2 from Student”;

ret = SQLPrepare(stmt, sql, SQL_NTS);

ret = SQLExecute(stmt);

while (SQLFetch(stmt) == SQL_SUCCESS)

{

ret = SQLGetData(stmt, 1, SQL_C_LONG, &id, sizeof(SQLINTEGER), NULL);

ret = SQLGetData(stmt, 2, SQL_C_CHAR, name, sizeof(name), NULL);

ret = SQLGetData(stmt, 3, SQL_C_LONG, &age, sizeof(SQLINTEGER), NULL);

ret = SQLGetData(stmt, 4, SQL_C_CHAR, score1, sizeof(score1), NULL);

ret = SQLGetData(stmt, 5, SQL_C_CHAR, score2, sizeof(score2), NULL);

printf(“%d\t%s\t%d\t%s\t%s\n”, id, name, age, score1, score2);

}

SQLFreeHandle(SQL_HANDLE_STMT, stmt);

“`

SQLPrepare函数的之一个参数指定了SQL语句的预处理句柄,第二个参数是执行的SQL语句,第三个参数是SQL语句的长度。SQLExecute函数用于执行SQL语句。通过SQLFetch和SQLGetData函数可以获取SQL语句的结果。

5. 查询方法二:使用SQLExecDirect直接执行SQL语句

使用SQLExecDirect直接执行SQL语句,可以查询数据库中的数据。以下是示例代码:

“`

SQLCHAR *sql = “select id, name, age, score1, score2 from Student”;

ret = SQLAllocHandle(SQL_HANDLE_STMT, dbc, &stmt);

if (ret == SQL_SUCCESS)

{

printf(“SQLAllocHandle success!\n”);

}

ret = SQLExecDirect(stmt, sql, SQL_NTS);

while (SQLFetch(stmt) == SQL_SUCCESS)

{

ret = SQLGetData(stmt, 1, SQL_C_LONG, &id, sizeof(SQLINTEGER), NULL);

ret = SQLGetData(stmt, 2, SQL_C_CHAR, name, sizeof(name), NULL);

ret = SQLGetData(stmt, 3, SQL_C_LONG, &age, sizeof(SQLINTEGER), NULL);

ret = SQLGetData(stmt, 4, SQL_C_CHAR, score1, sizeof(score1), NULL);

ret = SQLGetData(stmt, 5, SQL_C_CHAR, score2, sizeof(score2), NULL);

printf(“%d\t%s\t%d\t%s\t%s\n”, id, name, age, score1, score2);

}

SQLFreeHandle(SQL_HANDLE_STMT, stmt);

“`

SQLExecDirect函数用于执行SQL语句。通过SQLFetch和SQLGetData函数可以获取SQL语句的结果。

6. 插入数据到数据库

使用以下代码可以将一个学生的信息插入到数据库中:

“`

SQLCHAR *sql = “INSERT INTO Student(ID, Name, Age, Score1, Score2) VALUES(?, ?, ?, ?, ?)”;

ret = SQLPrepare(stmt, sql, SQL_NTS);

id = 10000;

SQLCHAR* name = “张三”;

age = 20;

SQLCHAR* score1 = “90”;

SQLCHAR* score2 = “89”;

ret = SQLBindParameter(stmt, 1, SQL_PARAM_INPUT, SQL_C_LONG, SQL_INTEGER, 0, 0, &id, sizeof(id), NULL);

ret = SQLBindParameter(stmt, 2, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_VARCHAR, 0, 0, name, strlen(name), NULL);

ret = SQLBindParameter(stmt, 3, SQL_PARAM_INPUT, SQL_C_LONG, SQL_INTEGER, 0, 0, &age, sizeof(age), NULL);

ret = SQLBindParameter(stmt, 4, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_VARCHAR, 0, 0, score1, strlen(score1), NULL);

ret = SQLBindParameter(stmt, 5, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_VARCHAR, 0, 0, score2, strlen(score2), NULL);

ret = SQLExecute(stmt);

“`

SQLPrepare函数用于准备SQL语句,在使用SQLBindParameter函数绑定参数。最后使用SQLExecute函数执行SQL语句插入数据到数据库中。

7. 修改数据

使用以下代码可以修改一个学生的成绩信息:

“`

SQLCHAR *sql = “UPDATE Student SET Score1 = ?, Score2 = ? WHERE ID = ?”;

ret = SQLPrepare(stmt, sql, SQL_NTS);

SQLCHAR* score1 = “91”;

SQLCHAR* score2 = “95”;

id = 10000;

ret = SQLBindParameter(stmt, 1, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_VARCHAR, 0, 0, score1, strlen(score1), NULL);

ret = SQLBindParameter(stmt, 2, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_VARCHAR, 0, 0, score2, strlen(score2), NULL);

ret = SQLBindParameter(stmt, 3, SQL_PARAM_INPUT, SQL_C_LONG, SQL_INTEGER, 0, 0, &id, sizeof(id), NULL);

ret = SQLExecute(stmt);

“`

SQL语句通过UPDATE关键字更新数据库中记录的内容。

8. 删除数据

使用以下代码删除一个学生的信息:

“`

SQLCHAR *sql = “DELETE FROM Student WHERE ID = ?”;

ret = SQLPrepare(stmt, sql, SQL_NTS);

id = 10000;

ret = SQLBindParameter(stmt, 1, SQL_PARAM_INPUT, SQL_C_LONG, SQL_INTEGER, 0, 0, &id, sizeof(id), NULL);

ret = SQLExecute(stmt);

“`

SQL语句通过DELETE FROM关键字删除数据库中的记录。

相关问题拓展阅读:

如何通过putty访问windows版本的db2

windows命令行下,需要先调用db2cmd,或者DB2CW.BAT(最终也是运行db2cmd)设置db2命令行解释器才能使用。否则直接运行db2会报告“DB21061E  Command line environment not initialized.”的错误。

  1.如果不想新建窗口,只需要设置db2clp的id,就可以了。如何获得id呢?打开另外一个db2cmd的窗口,运行set db2clp,就会显示db2clp的值

记住这个值,就可以在任何已经存在的cmd窗口中,设置db2clp的值为这个值就可以不需要新建窗口,运行db2命令了

   

 2.Cygwin 中使用DB2

   cygwin不介绍了,一直还在用windows,没换成linux,还是因为它的存在。

     两种方式,

  2.1一种在先运行db2cmd,然后再运行cygwin(需要将cygiwn安装目录下的bin目录添加到path变量中) 这时候就可以了.

2. 2 运用1中的方法,启动cygwin后运行export DB2CLP=XXXXXX,CLP指db2clp中的id

   

3. 如果安装了cygwin,并且开备渗启了sshd服务,就可以用putty等远仿裤脊程登陆工具访问本机了。这样做的好处,就是可以摆脱windows 自带的command命令行的一些缺点,特别是复制粘贴功能。也可以结合使用cygwin支持的一些linux命令。 

 

   3.1. 运用上面的方法,如果安装了cygwin,并且开启了sshd服务,就可以用putty等远程登陆工具访问本机了。这样做的好处,就是可以摆脱windows 自带的command命令行的一些缺点,特别是复制粘贴功能。也可以结合使用cygwin支持的一些linux命令。

  下面是具体做法。

  安装cygwin的工程中,选择net分类下sshd的包。

  安装完后,运行 ssh-host-config,配置ssd服务纯做

  net start sshd

  启动ssh的服务

  然后用ssh 访问本机localhost,登录用户名就是windows用户名.

    登陆成功后,在putty的命令行执行export CLP=XXXXXX, 这时候就可以执行db2。

每次这样设置,好烦啊(^_^),  再懒一点,

 1.写一个initclp.bat的拼处理文件,放入系统path目录下,通常,我自己放在Db2的安装目录bin下面。

 内容如下,后面是C:\mydb2cmd.sh是这条脚本的路径,可以自定义

 echo export DB2CLP=�2clp% > C:\mydb2cmd.sh

 2.打开cygwin,在home目录下,编辑 .bash_profile 文件,增加一行

 . /cygdrive/c/mydb2cmd.sh

  (注意格式,前面有”点空格”)

  好了。以后每次,只需要执行一次 db2cmd,然后在db2cmd窗口里运行自己的“山寨版的”的initclp脚本。

 

 再用putty 登陆自己的cygwin,当然可以用其它任何喜欢的ssh终端工具,可爱的cygwin assci的界面,db2也可以在这里面使用了

关于c访问db2数据库的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。


数据运维技术 » c语言实现对db2数据库的访问方法分享 (c访问db2数据库)