/*2015年5月15日:1、实现文本文件内数据格式的统一;2、实现文本文件导入MySQL数据库。(站在巨人的肩膀上学习,成长,感谢前辈们!!)*/
#include <string.h>
#include <stdlib.h>
#include <stdio.h>
#include <winsock2.h>
#include "mysql.h" /*连接MySQL数据库的头文件*/
#pragma comment(lib,"libmysql")
/*定义了一些数据库连接需要的宏*/
#define HOST "localhost"
#define USERNAME "root"
#define PASSWORD "123456"
#define DATABASE "ipinfo"
/*实现文件从in.txt中,写入到out.txt中,各字段之间为一个tab*/
void txtformat_exchange()
{
char data[100];
char ch;
FILE *fp = fopen("in.txt","r");
FILE *fd = fopen("out.txt","w");
while(!feof(fp))
{
fscanf(fp,"%s",&data);
fprintf(fd,"%s\t",data);
if((ch=fgetc(fp))=='\n')
{
fprintf(fd,"\n");
}
}
fclose(fp);
fclose(fd);
}
/*这个函数用来执行传入的sql語句*/
void exe_sql(char* sql) {
MYSQL my_connection; /*这是一个数据库连接*/
int res; /*执行sql語句后的返回标志*/
mysql_init(&my_connection); /*初始化mysql连接my_connection*/
/*这里就是用了mysql.h里的一个函数,用我们之前定义的那些宏建立mysql连接,并返回一个值,返回不为空证明连接是成功的*/
if (mysql_real_connect(&my_connection, HOST, USERNAME, PASSWORD,DATABASE, 0, NULL, CLIENT_FOUND_ROWS)) {
printf("数据库执行exe_sql连接成功!\n"); /*连接成功*/
mysql_query(&my_connection,"set character_set_database=gb2312"); /*这句话是设置查询编码为gb2312,这样支持中文.(疑问为什么utf8编码不可以)*/
/*下面这句话就是用mysql_query函数来执行我们刚刚传入的sql語句,这会返回一个int值,如果为0,证明語句执行成功*/
res = mysql_query(&my_connection,sql);
if (res) {
printf("Error:mysql_query !\n"); /*现在就代表执行失败了*/
mysql_close(&my_connection); /*不要忘了关闭连接*/
} else {/*现在就代表执行成功了*/
printf("%d 行受到影响!\n",mysql_affected_rows(&my_connection)); /*mysql_affected_rows会返回执行sql后影响的行数*/
mysql_close(&my_connection); /*不要忘了关闭连接*/
}
} else {
printf("数据库执行exe_sql连接失败!\n"); /*数据库连接失败*/
}
}
int main(int argc, char *argv[]) {
txtformat_exchange(); /*调用txt格式统一化函数*/
char *clr = "truncate table ipinfo"; /*数据库更新之前先清空表数据*/
exe_sql(clr);
char *exe = "load data local infile 'e:/data structure/updata/out.txt' into table ipinfo(Start,End,Address);"; /*数据库操作语句*/
exe_sql(exe); /*调用数据库操作函数*/
return 0;
#include <string.h>
#include <stdlib.h>
#include <stdio.h>
#include <winsock2.h>
#include "mysql.h" /*连接MySQL数据库的头文件*/
#pragma comment(lib,"libmysql")
/*定义了一些数据库连接需要的宏*/
#define HOST "localhost"
#define USERNAME "root"
#define PASSWORD "123456"
#define DATABASE "ipinfo"
/*实现文件从in.txt中,写入到out.txt中,各字段之间为一个tab*/
void txtformat_exchange()
{
char data[100];
char ch;
FILE *fp = fopen("in.txt","r");
FILE *fd = fopen("out.txt","w");
while(!feof(fp))
{
fscanf(fp,"%s",&data);
fprintf(fd,"%s\t",data);
if((ch=fgetc(fp))=='\n')
{
fprintf(fd,"\n");
}
}
fclose(fp);
fclose(fd);
}
/*这个函数用来执行传入的sql語句*/
void exe_sql(char* sql) {
MYSQL my_connection; /*这是一个数据库连接*/
int res; /*执行sql語句后的返回标志*/
mysql_init(&my_connection); /*初始化mysql连接my_connection*/
/*这里就是用了mysql.h里的一个函数,用我们之前定义的那些宏建立mysql连接,并返回一个值,返回不为空证明连接是成功的*/
if (mysql_real_connect(&my_connection, HOST, USERNAME, PASSWORD,DATABASE, 0, NULL, CLIENT_FOUND_ROWS)) {
printf("数据库执行exe_sql连接成功!\n"); /*连接成功*/
mysql_query(&my_connection,"set character_set_database=gb2312"); /*这句话是设置查询编码为gb2312,这样支持中文.(疑问为什么utf8编码不可以)*/
/*下面这句话就是用mysql_query函数来执行我们刚刚传入的sql語句,这会返回一个int值,如果为0,证明語句执行成功*/
res = mysql_query(&my_connection,sql);
if (res) {
printf("Error:mysql_query !\n"); /*现在就代表执行失败了*/
mysql_close(&my_connection); /*不要忘了关闭连接*/
} else {/*现在就代表执行成功了*/
printf("%d 行受到影响!\n",mysql_affected_rows(&my_connection)); /*mysql_affected_rows会返回执行sql后影响的行数*/
mysql_close(&my_connection); /*不要忘了关闭连接*/
}
} else {
printf("数据库执行exe_sql连接失败!\n"); /*数据库连接失败*/
}
}
int main(int argc, char *argv[]) {
txtformat_exchange(); /*调用txt格式统一化函数*/
char *clr = "truncate table ipinfo"; /*数据库更新之前先清空表数据*/
exe_sql(clr);
char *exe = "load data local infile 'e:/data structure/updata/out.txt' into table ipinfo(Start,End,Address);"; /*数据库操作语句*/
exe_sql(exe); /*调用数据库操作函数*/
return 0;
}
本部分功能的实现,主要是对文本文件中的数据和MySQL数据库进行操作,其格式转换和数据导入数据库由代码实现,可以简化操作。未来的思路是该部分功能可能用于数据更新按钮。