是否可以从库中连接到mysql?

时间:2017-11-16 02:16:23

标签: c++ mysql c dll shared-libraries

当我为外部应用程序编写我的第一个插件时遇到了很大的障碍。 插件作为DLL文件加载(SO for linux) 尝试连接到数据库,但它需要一些其他编译。 Everywhere写道,有必要使用给定的命令编译应用程序:

gcc exa_7.c -o exa_7 -std=c99  `mysql_config --cflags --libs'

该命令是最正确的,但我无法合并到属性:-c -fPIC

当我尝试在不传递MYSQL所需的属性的情况下触发代码时,它会导致很多错误:

dllmain.c:46:5: error: unknown type name ‘MYSQL’; did you mean ‘MYSQL_XID’?
     MYSQL      *MySQLConRet;
     ^~~~~
     MYSQL_XID
dllmain.c:47:5: error: unknown type name ‘MYSQL’; did you mean ‘MYSQL_XID’?
     MYSQL      *MySQLConnection = NULL;
     ^~~~~
     MYSQL_XID
dllmain.c:74:5: error: unknown type name ‘MYSQL_RES’; did you mean ‘MYSQL_XID’?
     MYSQL_RES      *mysqlResult = NULL;
     ^~~~~~~~~
     MYSQL_XID
dllmain.c:90:6: error: unknown type name ‘MYSQL_ROW’; did you mean ‘MYSQL_XID’?
      MYSQL_ROW       mysqlRow;
      ^~~~~~~~~
      MYSQL_XID
dllmain.c:91:6: error: unknown type name ‘MYSQL_FIELD’; did you mean ‘MYSQL_XID’?
      MYSQL_FIELD    *mysqlFields;
      ^~~~~~~~~~~
      MYSQL_XID

我的清单包括:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <assert.h>
#include <unistd.h>
#include <mysql/mysql.h>
#include <mysql/my_global.h>
#include <mysql/my_config.h>
#include <sys/socket.h> 
#include <arpa/inet.h>
#include "ts3_functions.h"
#include "plugin.h"
#include <pthread.h>
//(more includes, but not important)

你知道如何解决这个问题吗?

//编辑: 删除#include <mysql/mysql.h>

的评论

现在我使用以下命令编译它:gcc -pthread -c -fPIC -o test.o dllmain.c

编译正确运行(没有任何错误),但在运行程序时会收到消息:undefined symbol: mysql_init

问题可能在代码中?:

MYSQL      *MySQLConRet;
MYSQL      *MySQLConnection = NULL;

MySQLConnection = mysql_init( NULL );
MySQLConRet = mysql_real_connect( MySQLConnection,
                                  hostName, 
                                  userId, 
                                  password, 
                                  DB, 
                                  0, 
                                  NULL,
                                  0 );

if ( MySQLConRet == NULL ) {
    printf(mysql_error(MySQLConnection) );
    exit(1);
}

1 个答案:

答案 0 :(得分:0)

您尚未加入<mysql/mysql.h>。取消注释该行。使用MySQL API需要此文件。 <mysql/my_global.h>是一个内部标头,用于包含公共系统头文件和定义实用程序宏 - 它是替代<mysql/mysql.h>,并且不应直接包含在内。