3

这是我要运行的代码。它编译得很好,直到昨天都很好。

#include <my_global.h>
#include <mysql.h>

int main(int argc, char **argv)
{

  MYSQL *conn;
  MYSQL_RES *result;
  MYSQL_ROW row;
  int num_fields;
  int i;

  conn = mysql_init(NULL);
  mysql_real_connect(conn, "hostname", "username", "password", "database_name", 0, NULL, 0);

  mysql_query(conn, "SELECT * FROM tabletest");
  result = mysql_store_result(conn);

  num_fields = mysql_num_fields(result);

  while ((row = mysql_fetch_row(result)))
  {
      for(i = 0; i < num_fields; i++)
      {
          printf("%s ", row[i] ? row[i] : "NULL");
      }
      printf("\n");
  }

  mysql_free_result(result);
  mysql_close(conn);

}

请注意,mysql_real_connect()这里的参数对于隐私来说是通用的,但就像我说的,它昨天起作用了。当我编译成功后尝试运行代码时,我得到:

Segmentation fault (core dumped)
4

1 回答 1

4

Paddy指出了关键问题,我没有查错。错误检查后,我发现我没有被授予访问远程服务器的权限,并且正在获取

Error 1045: Access denied for user 'username'@'ip' (using password: YES)

然后我意识到我的电脑在开机后IP地址发生了变化。我从来不知道这发生了。所以我不得不回到cPanel,将我的“新”IP地址添加到MySQL的远程访问列表中,它就可以工作了。现在的问题是找出我的 IP 地址如何保持静态。

这个故事的寓意是总是处理错误。

于 2012-10-17T01:31:04.073 回答