Chinaunix首页 | 论坛 | 博客
  • 博客访问: 731384
  • 博文数量: 741
  • 博客积分: 6000
  • 博客等级: 准将
  • 技术积分: 4825
  • 用 户 组: 普通用户
  • 注册时间: 2008-09-18 11:18
文章分类

全部博文(741)

文章存档

2011年(1)

2008年(740)

我的朋友

分类:

2008-09-18 11:31:50

一段连接mysql的c代码,编译一直不能通过,苦闷中,求助~
#include
#include
#include
#include "/usr/local/mysql/include/mysql.h"


int main(int argc, char *argv[]) {
        MYSQL my_connection;
        MYSQL_RES *res_ptr;   /*指向检索的结果存放地址的指针*/
        MYSQL_ROW sqlrow;     /*返回的记录信息*/
        MYSQL_FIELD *fd;      /*字段结构指针*/
        char aszflds[25][25]; /*用来存放各字段名*/
//        char szTargetDSN[]=db; /*用来存放数据库的名字*/
        int res;             /*执行查询操作后的返回标志*/
        int i,j,k;

        mysql_init(&my_connection);

        /*mysql_real_connect(&mysql,host,user,passwd,dbname,0,NULL,0) == NULL)*/
        if (mysql_real_connect(&my_connection, "root", "root", "123456","authority",0,NULL,CLIENT_FOUND_ROWS))
        {
            printf("Connection success\n");
            res = mysql_query(&my_connection, "select result from authority where id=uid");
       
            if (res)
            {
                printf("SELECT error:%s\n",mysql_error(&my_connection));
            }
            else
            {
               res_ptr=mysql_store_result(&my_connection);
               if(res_ptr)
               {
                      printf("Retrieved %lu Rows\n",(unsigned long)mysql_num_rows(res_ptr));
                      /*取得各字段名*/
                      for(i=0;fd=mysql_fetch_field(res_ptr);i++)
                             strcpy(aszflds,fd->name);
                      /*输出各条记录*/
                      printf("下面是检索出的各条记录信息:\n");
                      j=mysql_num_fields(res_ptr);
                      for(i=0;i                       printf("%s\t",aszflds);
                      printf("\n");
                      while((sqlrow=mysql_fetch_row(res_ptr)))
                      {
                             for(i=0;i                              printf("%s\t",sqlrow);
                             printf("\n");
                      }
                      if (mysql_errno(&my_connection))
                      {
                             fprintf(stderr,"Retrive error:s\n",mysql_error(&my_connection));
                      }
               }
               mysql_free_result(res_ptr);
               }
            mysql_close(&my_connection);
        }
       
        else
        {
            fprintf(stderr, "Connection failed\n");
       
            if (mysql_errno(&my_connection))
            {
                fprintf(stderr, "Connection error %d: %s\n",
                mysql_errno(&my_connection),
                mysql_error(&my_connection));
                }
        }
            return EXIT_SUCCESS;
}



gcc -o query query.c -L /usr/local/mysql/lib/*.a -lz  之后就报如下错误:

lib/libmysqlclient.a (password.o) (.text+0x308): In function 'scramble_323':
undefined reference to 'floor'.


[ 本帖最后由 houhou_mao 于 2008-5-29 14:11 编辑 ]

--------------------next---------------------

阅读(330) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~