发表时间: 2006-12-17 16:45    作者: llehotnwod    来源: PHPChina 开源社区门户

mysql:

------------------------------------------------------------------

mysql> create table zy ( xuhao int(6) unsigned zerofill auto_increment

primary key not null, fenqu char(50) character set utf8, bianma int(6)

unsigned zerofill, liexin char(50) character set utf8, weizhi char(50)

character set utf8 );

Query OK, 0 rows affected (0.62 sec)

mysql> describe zy;

+--------+--------------------------+------+-----+---------+----------------+

| Field  | Type                     | Null | Key | Default | Extra

|

+--------+--------------------------+------+-----+---------+----------------+

| xuhao  | int(6) unsigned zerofill | NO   | PRI | NULL    |

auto_increment |

| fenqu  | char(50)                 | YES  |     | NULL    |

|

| bianma | int(6) unsigned zerofill | YES  |     | NULL    |

|

| liexin | char(50)                 | YES  |     | NULL    |

|

| weizhi | char(50)                 | YES  |     | NULL    |

|

+--------+--------------------------+------+-----+---------+----------------+

5 rows in set (0.28 sec)

------------------------------------------------------------------

输入文件:

file ~/doc

/home/soj/doc: UTF-8 Unicode text

cat ~/doc  部分内容

283     碌?露镁路??酶   020179  ?庐?梅?赂?戮

露镁虏茫?梅?掳?酶

284     碌?露镁路??酶   020180  ??潞?碌煤路搂

露镁虏茫?梅?掳?酶

285     碌?露镁路??酶   020181  路?禄冒路搂

露镁虏茫?梅?掳?酶

286     碌?露镁路??酶   020182  路?禄冒路搂

露镁虏茫?梅?掳?酶

事先我用iconv将其转成了utf-8,在C中实在是不会,sigh~~~~

程序代码main.c:

#include

#include

#include

#include

//#include

//#include "/usr/src/sys/sys/iconv.h"

//#include "/usr/src/bin/csh/iconv.h"

#include "/usr/local/include/mysql/mysql.h"

int

main(int argc,char **argv)

{

MYSQL           mysql;

FILE            *fp;

if( 2 != argc ){

fprintf(stderr,"Usage:./prog inputfile\n");

exit(-1);

}

if( NULL == (fp=fopen(argv[1],"r")) ){

fprintf(stderr,"%s\n",strerror(errno));

exit(-1);

}

fprintf(stdout,"file %s opend...\n",argv[1]);

mysql_init(&mysql);

if(NULL==mysql_real_connect(&mysql,"localhost","zhongyi","localhost","ZhongYi",0,NULL,0)){

fprintf(stderr,"Failed to connect to database: Error:

%s\n",mysql_error(&mysql));

exit(-1);

}

fprintf(stdout,"DataBase Connected...\n");

if( 0 != mysql_options(&mysql,MYSQL_SET_CHARSET_NAME,"utf8")){

fprintf(stderr,"mysql_options Error:

%s\n",mysql_error(&mysql));

}

if( 0 != mysql_set_character_set(&mysql,"utf8") ){

fprintf(stderr,"mysql_set_character_set Error:

%s\n",mysql_error(&mysql));

}

/*  --------------------------------- */

/*  021     第一分区    010021  光电感烟    一层东后区

*/

for(char buf[4096]; NULL != fgets(buf,4096,fp); ){

/*

* | fenqu  | char(30)

* | bianma | int(6) unsigned zerofill

* | liexin | char(30)

* | weizhi | char(30)

*/

char query[1024]="INSERT INTO zy(fenqu,bianma,liexin,weizhi)

VALUES(‘";

char *iter_b,*iter_e;

for(iter_b=buf; 0 < *iter_b; ++iter_b);

for(iter_e=iter_b; 0 > *iter_e; iter_e+=2);

strncat(query,iter_b,iter_e-iter_b);

strcat(query,"‘,");

for(iter_b=iter_e; ‘ ‘==*iter_b; ++iter_b);

for(iter_e=iter_b; ‘ ‘!=*iter_e; ++iter_e);

strncat(query,iter_b,iter_e-iter_b);

strcat(query,",‘");

for(iter_b=iter_e; 0 < *iter_b; ++iter_b);

for(iter_e=iter_b; 0 > *iter_e; iter_e+=2);

strncat(query,iter_b,iter_e-iter_b);

strcat(query,"‘,‘");

for(iter_b=iter_e; 0 < *iter_b; ++iter_b);

for(iter_e=iter_b; 0 > *iter_e; iter_e+=2);

strncat(query,iter_b,iter_e-iter_b);

strcat(query,"‘)");

/*  iconv */

/*

iconv_t   cd;

char outbuf[1024];

size_t in=strlen(query),out=1024;

if( (iconv_t)-1 == (cd = iconv_open("UTF-8","GBK")) ){

fprintf(stderr,"Iconv_open Error: %s\n",strerror(errno));

exit(-1);

}

if( (size_t)-1 == iconv(cd,(char **)&query,(size_t *)&in,(char

**)&outbuf,(size_t *)&out) ){

fprintf(stderr,"Iconv Eoor: %s\n",strerror(errno));

exit(-1);

}

*/

if( mysql_real_query(&mysql,query,strlen(query)) ){

fprintf(stderr,"Error making query:

%s\n",mysql_error(&mysql));

}

/*

if( -1 == iconv_close(cd) ){

fprintf(stderr,"Iconv_close Error: %s\n",strerror(errno));

exit(-1);

}

*/

}

fclose(fp);

mysql_close(&mysql);

exit(0);

}

编译:

gcc -std=c99 -L /usr/local/lib/mysql/ -lmysqlclient -I

/usr/local/include/mysql/ main.c -o sql

查看结果:

mysql> select * from zy;

+--------+----------+--------+----------+----------------+

| xuhao  | fenqu    | bianma | liexin   | weizhi         |

+--------+----------+--------+----------+----------------+

| 000001 | 第一分区 | 001001 | 光电感烟 | 二层东后区     |

| 000002 | 第一分区 | 001002 | 光电感烟 | 二层东后区     |

| 000003 | 第一分区 | 001003 | 光电感烟 | 二层东后区     |

| 000004 | 第一分区 | 001004 | 光电感烟 | 二层东后区     |

| 000005 | 第一分区 | 001005 | 光电感烟 | 二层东后区     |

| 000006 | 第一分区 | 001006 | 光电感烟 | 二层东后区     |

| 000007 | 第一分区 | 001007 | 光电感烟 | 二层东后区     |

| 000008 | 第一分区 | 001008 | 光电感烟 | 二层东后区     |

| 000009 | 第一分区 | 001009 | 光电感烟 | 二层东后区     |

.................................................................

| 000285 | 第二分区 | 020181 | 防火阀   | 二层西前区     |

| 000286 | 第二分区 | 020182 | 防火阀   | 二层西前区     |

+--------+----------+--------+----------+----------------+

c 文档写入mysql_一个将文件数据(汉字)导入到mysql的C程序_原创文档_论坛_PHPChina 开源社区......相关推荐

  1. .net excel导入mysql_.NET Core使用NPOI将Excel中的数据批量导入到MySQL - 追逐时光者 - 博客园...

    前言: 在之前的几篇博客中写过.NET Core使用NPOI导出Word和Excel的文章,今天把同样我们日常开发中比较常用的使用Excel导入数据到MySQL数据库中的文章给安排上.与此同时还把NP ...

  2. [Excel知识技能] Txt文件数据批量导入Excel

    记录(日期: 2022/5/20) 在实际工作中,遇到过将Txt格式的数据导入到Excel中,为此特意记录以下操作过程,便于日后的回顾和学习 需要导入的文本文件如下图所示: Txt文本数据源 Site ...

  3. c语言创建写入和读取TXT文件数据

    下面是一个简单文件读取程序,首先是写数据,将数字0~9写入到data.txt文件中,然后再从data.txt中读取数据,将读到的数据存到数组a[10]中,并且打印到控制台上. 下面是程序: [cpp] ...

  4. sql2000导出mysql_如何将sql2000的数据库导入到mysql中?

    展开全部 先用SQl2000导出e68a843231313335323631343130323136353331333262373366文本文件,把后缀名改为CSv,再从Mysql中一导入OK 参考: ...

  5. html文档本质是一个什么文件,html文件是什么

    html文件中文名是超文本标记语言或超文本链接标示语言,是一种制作万维网页面的标准语言,是万维网浏览器使用的一种语言,它消除了不同计算机之间信息交流的障碍. html是目前网络上应用最为广泛的语言,也 ...

  6. html文档本质是一个什么文件,html是什么文件

    html是超文本标记语言文件文档,是扩展名为".html"的文件.HTML文件是可以被多种网页浏览器读取,传递各类资讯的文件.HTML文件会被存储在分布于世界各地的服务器硬盘上,通 ...

  7. 聊天记录存redis还是mysql_一个小小的签到功能,到底用MySQL还是Redis?

    今天,看下签到功能怎么选择? 现在的网站和app开发中,签到是一个很常见的功能,如微博签到送积分,签到排行榜~ 微博签到 如移动app ,签到送流量等活动, 移动app签到 用户签到是提高用户粘性的有 ...

  8. tidb vs mysql_一个长耗时SQL在TiDB和Mysql上的耗时测试

    之前看到的TiDB和MySql的性能对比都是大量短耗时请求下的压测,单机情况下TiDB和MySql的确有些差距,不过笔者最近碰到的场景更多是sql要扫描的行数不小的情况下单sql比较耗时的问题,所以自 ...

  9. php中excel文件数据的导入和导出

    1.先下载 https://github.com/PHPOffice/PHPExcel 2.将SDK解压之后的Class文件拷贝到自己的项目. 一.数据导入 /*** 数据导入* @param str ...

最新文章

  1. 【精品】【分享】盖茨留给职场工作者的十句警告
  2. html图片怎么设置悬浮效果,图片漂浮效果js实现
  3. win10子linux如何重置密码,Win10如何使用Windows PowerShell命令重置本地账户密码
  4. 2017.9.19 L语言 失败总结
  5. 重建程序员能力(2)-如何使asp.net mvc应用增加js和其他功能
  6. nodejs创建http服务器
  7. English trip EM2-LP-2A Around the world Teacher:Taylor
  8. 鹅厂员工平均月薪7万刷屏!公司每天赚9.5亿,养5.46万人
  9. java map格式化_字符串模板格式化输出map 值
  10. 第十七届全国大学生智能汽车竞赛全国总决赛参赛队伍奖项公告
  11. win10 远程桌面卡顿_win10系统使用远程桌面卡顿的解决教程
  12. Jvm面试题及答案(2021年Jvm面试题大全带答案)
  13. Css3:选择器、字体和颜色样式
  14. c++ 运算符重载(简单易懂)
  15. 如何通过域名访问web项目
  16. Java代码安装maven jar_Java中Maven项目导出jar包配置的示例代码
  17. 《基于小型训练集的深度学习迁移的食用毒蘑菇机器视觉识别系统》论文笔记
  18. 蓝牙作为智能钥匙的媒介
  19. 如何在GitHub上创建自己的仓库?
  20. 如何监听storage仓库变化(只限localstorage)

热门文章

  1. 白盒测试技术详细,有例题——软件质量保证与测试
  2. ctr镜像导入报错ctr: content digest sha256:xxxxxx not found
  3. 蹒跚学步,走出Scala的下一步
  4. 目标检测算法——YOLOv5/YOLOv7改进之结合CBAM注意力机制
  5. 计算机cmos是由rom组成,什么是CMOS与BIOS?又有什么区别?
  6. android 8 更新不了机,小米的 Bug 太多?小米 A1 已暂停 Android 8.0 升级
  7. crtmpserver搭建直播点播平台
  8. 端到端一致性,流系统Spark/Flink/Kafka/DataFlow对比总结(压箱宝具呕血之作)
  9. Linux中su的使用说明
  10. html点击跳转客服聊天,小能客服点击后(新的交互逻辑).html