- 论坛徽章:
- 0
|
怎样用c/c++编程连接mysql数据库?
http://www.mysql.com/doc/en/C.html
[转贴自http://homepage.qdcatv.com.cn/antonio/mysql/mysql.htm]
执行一个查询有以下几个步骤要做。首先执行一个查询,然后保存结果,
得到的是一个子集。这里是一个小例子:- #include
- #include
- #include "mysql.h"
-
- MYSQL mysql;
- MYSQL_RES *res;
- MYSQL_ROW row;
-
- void exiterr(int exitcode)
- {
- fprintf( stderr, "%s\n", mysql_error(&mysql) );
- exit( exitcode );
- }
-
- int main()
- {
- uint i = 0;
-
- if (!(mysql_connect(&mysql,"host","username","password")))
- exiterr(1);
-
- if (mysql_select_db(&mysql,"payroll"))
- exiterr(2);
-
- if (mysql_query(&mysql,"SELECT name,rate FROM emp_master"))
- exiterr(3);
-
- if (!(res = mysql_store_result(&mysql)))
- exiterr(4);
-
- while((row = mysql_fetch_row(res))) {
- for (i=0 ; i < mysql_num_fields(res); i++)
- printf("%s\n",row[i]);
- }
-
- mysql_free_result(res);
- mysql_close(&mysql);
- }
复制代码 mysql_query 函数将把查询送给服务器,如果查询成功,调用mysql_store_result
函数将分配一个MYSQL_RES 结构并且重新从服务器获得一个结果集。你可以用
mysql_fetch_row 函数来查看数据。这样做你将获得一个 MYSQL_ROW 指针指向数
据中的一行。 MYSQL_ROW 指针是一简单的字符串数组。所有的数据类型被转换成
字符串送到客户端。
mysql_num_fields 函数将告诉你返回的列数。你可以继续调用 mysql_fetch_row
直到它返回一个空指针以得到查询中的每一行。
注意在这个例子里,我们没有检查有空指针的列。如果你不使用非空列的表,那么
你必须检查一个特殊行的列是否为空。
一旦你使用完毕一个结果集,你必须释放它。这通过 mysql_free_result 来完成。
最后调用 mysql_close 来关闭你和数据库之间的连接。
查看结果集
你可以不用调用 mysql_fetch_row 就查出返回的结果集共有多少行。这由
int mysql_num_rows(MYSQL_RES *result)来完成。
改变到被下一个 mysql_fetch_row 调用返回的行,你可以用
void mysql_data_seek(MYSQL_RES *res, uint offset) 改变到任意一行。
获得更多的信息
你可以使用这几个额外的函数来找出关于一个查询的更多的信息,并从服务器获得
这些信息。
如果你执行一个UPDATE, INSERT 或者 DELETE 查询,你可以用
int mysql_affected_rows 来查出共有多少行数据被你影响到。
如果在你的数据库里有二进制数据,那么得知数据的长度将是有用的。unsigned
int *mysql_fetch_lengths(MYSQL_RES *mysql) 将返回一指出了结果集中每一列
的长度的整型数组。
当你插入一个带有 AUTO_INCREMENT 列的表的时候,你可以用
int mysql_insert_id(MYSQL *mysql) 来查出生成的那一行的ID。
======================
我连过成功了!- #include "/include/mysql/mysql.h" /*为绝对路径*/
- #include <stdio.h>
-
- int main(int argc,char *argv[])
- {
- char *user = "root", *pwd = "mysql", *dbname = "mysql";
- MYSQL mysql;
- MYSQL_RES *mysql_ret;
- MYSQL_ROW mysql_row;
- unsigned long num_rows;
- int ret;
-
- mysql_init(&mysql);
-
- if(mysql_real_connect(&mysql,NULL,user,pwd,dbname,0,NULL,0))
- {
- printf("Connection success!\n");
- ret = mysql_query(&mysql,"select * from user");
- if(!ret)
- {
- printf("Query Success!\n");
- mysql_ret = mysql_store_result(&mysql);
- if(mysql_ret != NULL)
- {
- printf("Store Result Success!\n");
- num_rows = mysql_num_rows(mysql_ret);
- if(num_rows != 0)
- {
- printf("%d\n",num_rows);
- while(mysql_row = mysql_fetch_row(mysql_ret))
- {
- printf("%s\t%s\t%s\t%s\t%s\t%s\n",mysql_row[0],mysql_row[1],mysql_row[2],mysql_row[3],mysql_row[4],mysql_row[5]);
- }
- }
- else
- {
- printf("mysql_num_rows Failed!\n");
- exit(-1);
- }
- mysql_free_result(mysql_ret);
- exit(0);
- }
- else
- {
- printf("Store Result Failed!\n");
- exit(-1);
- }
- }
- else
- {
- printf("Query Failed!\n");
- exit(-1);
- }
- }
- else
- {
- printf("Connection Failed\n");
- exit(-1);
- }
- }
复制代码 如果你包含了正确的头文件而在连接的时候, 告诉你没有符号连接
你应该连接你需要的库
我的/lib/mysql/libmysqlclient.so下面
gcc -L/lib/mysql -lmysqlclient -o tes tes.c 进行编译
RedHat_shu@hotmail.com |
|