读取数据库信息,使用QR码API批量生成二维码并下载到本地

来源:互联网 发布:无锡关键词优化 编辑:程序博客网 时间:2024/06/06 19:00

前言:宿舍没网了,赖在公司没事干,写点东西记录吧。。目前也是刚开始接触数据库,写的不好,请见谅,尽力用简洁步骤完成操作,上可执行的源代码,于人于己方便,大家都懂哈。。另我用的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;
}

有疑问的可以留言,大家相互学习,早日摆脱渣渣的水平。

备注:我渴望成功,虽然程序员没有出路,但我知道努力后多拿一块钱,就可以多喝一瓶自来水。

原创粉丝点击