执行一个查询有以下几个步骤要做。首先执行一个查询,然后保存结果,
得到的是一个子集。这里是一个小例子:
#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 进行编译
附mysql的windows安装以及函数说明:
通过VC开发MySQL数据库应用软件有多种方式:
一、通过MyODBC界面
二、通过Connector/C++l界面
三、通过MySQL C API界面
四、第三方封装的MySQL类
在经过反复比较,我还是选择了MySQL C API方式来进行MySQL的开发。
在VC中使用MySQL的步骤如下:
1、下载MySQL的服务器/客户端安装包
官方下载地址如下:
http://www.mysql.com/downloads/mysql-4.0.html
由于我的开发环境是Windows,所以我下载的是MySQL for Windows V4.0.12
2、安装MySQL服务器/客户端包
一般情况,选择下一步就行了。
默认情况,MySQL会安装到C:/mysql下。
3、在VC中设置其开发环境
[选项/项目/VC目录]
a.设置包含路径为c:/mysql/include
b.设置引用路径为c:/mysql/include
c.设置库路径为c:/mysql/lib/debug
[项目属性]
d.在设置链接器-输入-附加依赖项为libmySQL.lib
e.在stdafx.h中加入以下行:
#include <winsock.h>
#include "mysql.h"
4、至此就可以使用C API函数进行开发了。
FAQ:
1.若出现无法使用mysql.h定义的类型的错误时,可重新生成工程即可.
2.若出现链接错误,可将libmySQL.dll文件拷贝到工程当前目录下.
MySQL提供了很多函数来对数据库进行操作,大致可以分为以下几类:
第一部分 控制类函数
mysql_init()初始化MySQL对象
mysql_options()设置连接选项
mysql_real_connect()连接到MySQL数据库
mysql_real_escape_string()将查询串合法化
mysql_query()发出一个以空字符结束的查询串
mysql_real_query()发出一个查询串
mysql_store_result()一次性传送结果
mysql_use_result()逐行传送结果
mysql_free_result()释放结果集
mysql_change_user()改变用户
mysql_select_db()改变默认数据库
mysql_debug()送出调试信息
mysql_dump_debug_info()转储调试信息
mysql_ping()测试数据库是否处于活动状态
mysql_shutdown()请求数据库SHUTDOWN
mysql_close()关闭数据库连接
第二部分 信息获取类函数
mysql_character_set_name()获取默认字符集
mysql_get_client_info()获取客户端信息
mysql_host_info()获取主机信息
mysql_get_proto_info()获取协议信息
mysql_get_server_info()获取服务器信息
mysql_info()获取部分查询语句的附加信息
mysql_stat()获取数据库状态
mysql_list_dbs()获取数据库列表
mysql_list_tables()获取数据表列表
mysql_list_fields()获取字段列表
第三部分 行列类操作函数
mysql_field_count()获取字段数
mysql_affected_rows()获取受影响的行数
mysql_insert_id()获取AUTO_INCREMENT列的ID值
mysql_num_fields()获取结果集中的字段数
mysql_field_tell()获取当前字段位置
mysql_field_seek()定位字段
mysql_fetch_field()获取当前字段
mysql_fetch_field_direct()获取指定字段
mysql_frtch_fields()获取所有字段的数组
mysql_num_rows()获取行数
mysql_fetch_lengths()获取行长度
mysql_row_tell()获取当前行位置
mysql_row_seek()行定位
mysql_data_seek()行定位
mysql_fetch_row()获取当前行
第四部分 线程类操作函数
mysql_list_processes()返回所有线程列表
mysql_thread_id()获取当前线程ID
mysql_thread_safe()是否支持线程方式
mysql_kill()杀列一个线程
第五部分 出错处理类函数
mysql_errno()获取错误号
mysql_error()获取错误信息
第六部分 已过时的函数
mysql_connect()
mysql_create_db()
mysql_drop_db()
mysql_eof()
mysql_reload()
mysql_escape_string()