C语言实现:1、实现文本文件内数据格式的统一;2、实现文本文件导入MySQL数据库。

/*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; 


本部分功能的实现,主要是对文本文件中的数据和MySQL数据库进行操作,其格式转换和数据导入数据库由代码实现,可以简化操作。未来的思路是该部分功能可能用于数据更新按钮。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值