これは、Linux プラットフォームで、MySQL サーバーに接続し、単一のクエリを持つテキスト ファイルから SQL クエリを実行する C プログラムです。
ここでは、まずデータベース サーバーとの接続が確立されます。
次の行
show tables
「text.txt」という名前のテキストファイルから読み取られます
これは、line という文字列に格納されます。そして、この文字列は MySQL C API の関数 mysql_query に渡されます。次に、MySQL データベースは、関数 mysql_use_result を使用してテーブルの名前である結果を返します。
上記は、このコードの正しい動作です。
しかし、string,line (ファイル "text.txt" のデータを含む) を mysql_query() に渡す際にエラーが発生します。
エラー:
You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '�����o���+N�J�O�Q�' at line 2
これは、文字列、行を介してファイル内の実際のデータとともにガベージ値も渡されることを意味します。どうすればこれを修正できますか。
コード:
#include mysql.h
#include stdio.h
main()
{
MYSQL *conn;
MYSQL_RES *res;
MYSQL_ROW row;
char *server = "localhost";
char *user = "root";
char *password = "1"; /* set me first */
char *database = "mysql";
conn = mysql_init(NULL);
/* Connect to database */
if (!mysql_real_connect(conn, server,
user, password, database, 0, NULL, 0)) {
fprintf(stderr, "%s\n", mysql_error(conn));
exit(1);
}
/*reading query from text file*/
int fd,i=0;
char line[300];
char ch1;
FILE *fp;
fp =fopen("text.txt","r");
if(fp ==NULL )
{
printf("File open error.\n");
exit(-1);
}
ch1 = getc(fp);
while (ch1 != EOF)
{
line[i]=ch1;
ch1 = getc(fp);
i++;
}
printf("%s",line);
fclose(fp);
/* send SQL query */
if (mysql_query(conn,line )) {
fprintf(stderr, "%s\n", mysql_error(conn));
exit(1);
}
res = mysql_use_result(conn);
/* output table name */
printf("MySQL Tables in mysql database:\n");
while ((row = mysql_fetch_row(res)) != NULL)
printf("%s \n", row[0]);
/* close connection */
mysql_free_result(res);
mysql_close(conn);
}