前言:宿舍没网了,赖在公司没事干,写点东西记录吧。。目前也是刚开始接触数据库,写的不好,请见谅,尽力用简洁步骤完成操作,上可执行的源代码,于人于己方便,大家都懂哈。。另我用的QR码API为联图的,因为这个网上的介绍很多,用的也很广。废话结束,开干。。
平台:win10(64bit)、vs2008、mysql5.1.73(64bit)
注:试运行程序的时候总提示无法解析的外部符号,是因为建的工程是win32,debug时改成x64平台就好了,因为这个墨迹了一天多,哎。。
预准备一:我用的mysql的msi安装文件,安装时选择的complete,一直next到尾,数据库密码设的102512(代码里需要用到,你的数据库设的什么就改成相应的密码),安装结束,打开mysql的命令窗口(在左下角所有程序目录mysql下边有),输入密码,进入命令行操作界面。底下创建数据库和数据表并插入数据见我的另一篇博客:http://blog.csdn.net/fx_odyssey/article/details/72866074,本篇批量生成的二维码附带文本信息用的是单条目信息,所以添入数据表数据时仅一列就够了。
预准备二:将mysql安装路径下带mysql.h文件的路径、带libmysql.lib文件的路径分别设置为所建vs2008工程属性的附加头文件路径、附加lib库文件路径;附加库目录添加libmysql.lib;将libmysql.dll文件拷贝到工程目录下。
准备工作结束,以下为源码:
//#pragma comment(linker, "/subsystem:\"windows\" /entry:\"mainCRTStartup\"" )//屏蔽dos窗口
#pragma comment( lib, "libmysql.lib")
#pragma comment(lib, "urlmon.lib")//下载网络图片用
#include <winsock2.h>//定义socket
#include <WINDOWS.H>
#include <iostream>
#include "mysql.h"
int main(char **args)
{
char *url = "http://tool.kd128.com/qrcode?text=";//这个是联图QR码API的基址,后边跟二维码信息,详细问度娘//http://qr.liantu.com/api.PHP?&bg=ffffff&text=
char *urlbase = new char[256];
char *filenamebase = new char[256];
const char user[] = "root";
const char password[] = "123456";//个人设置的数据库密码
const char host[] = "localhost";
const char table[] = "abc";//个人设置的数据库名称
unsigned int port = 3306;//默认端口
MYSQL mysql;
MYSQL_RES *result;
MYSQL_ROW sql_row;
MYSQL_FIELD *fd;
char column[32][32];
int res;
mysql_init(&mysql);
if (mysql_real_connect(&mysql, host, user, password, table, port, NULL, 0))//判断是否连接数据库
{
std::cout << "connect succeed !" << std::endl;
res = mysql_query(&mysql, "select *from mytable");//事先创建的数据库中的数据表名称为mytable
if (!res)
{
result = mysql_store_result(&mysql);
if (result)
{
int i, j;
std::cout << "number of result: " << (unsigned long)mysql_num_rows(result) << std::endl;
for (i = 0; fd = mysql_fetch_field(result); i++)
{
strcpy(column[i], fd->name);
}
j = mysql_num_fields(result);
for (i = 0; i < j; i++)
{
//printf("%s\t", column[i]);
}
printf("\n");
while (sql_row = mysql_fetch_row(result))
{
for (i = 0; i < j; i++)
{
if (j = 1)
{
//printf("%s\t", sql_row[i]);
strcpy(urlbase, url);
strcat(urlbase, sql_row[i]);
strcpy(filenamebase, "./Download Pictures/");//我事先在工程目录下创建了download pictures这个文件夹,如果嫌麻烦,删掉,改成:“./";
strcat(filenamebase, sql_row[i]);
strcat(filenamebase, ".bmp");
if (URLDownloadToFile(NULL, urlbase, filenamebase, 0, NULL) != S_OK)//下载图片,简单明了,小钢炮般的体验
perror("Download Picture False.");
}
else
{
//此处为多表头数据表数据处理
}
}
printf("\n");
}
}
}
else
{
std::cout << "query sql failed !" << std::endl;
}
}
else
{
std::cout << "connect failed !" << std::endl;
int i = mysql_errno(&mysql);
const char * s = mysql_error(&mysql);
std::cout << s << std::endl;
}
if (result != NULL)
mysql_free_result(result);
delete[] urlbase;
delete[] filenamebase;
mysql_close(&mysql);
//system("pause");
return 0;
}
有疑问的可以留言,大家相互学习,早日摆脱渣渣的水平。
备注:我渴望成功,虽然程序员没有出路,但我知道努力后多拿一块钱,就可以多喝一瓶自来水。