今天碰到一个问题,load data infile时总是不能完全把文件中的数据倒入到数据库中。
各种计数表示文件中已经写了比如2000行,但数据库中只有那么1500行左右,于是在load之后getchar()暂停程序执行,对文件和数据库进行比对,惊奇的发现文件中竟然也只有1500多行,和数据库保持一致。
奇怪了!计数明明显示写入了2000行啊,怎么只有1500多行呢!ls一看文件大小竟然是128K。后来改成写入3000行,文件中只有2800多行,再ls一下,竟然是256K。
啥情况,linux下这个文件难道只能是128K整数倍?后来写了个单独小程序测量了一把,终于得出结论:
一个文件在写入之后没有关闭的情况下,只能写入64K倍数的字符,多余的在缓存当中,还不在磁盘上。只有在下次读出之前将其进行关闭,文件才能写入完全,这时候写入多少就是多少了,读出自然也是正确的!
嗯,就记录这些。