数据库中海量文件的批量转移方法

数据库 SQL Server
今天我们将谈到的是在数据库中海量文件的批量转移,如果这样的问题不解决会影响到相关文件的维护工作。

事情的经过是这样子的!数据库A表添加一条记录,**系统中B目录下就会多出5n个文件。随着系统运行3年多,B目录中的文件数已高达2M多,而这些文件恰恰又是用户高度频繁访问的。于是问题就来了,一方面是用户访问文件速度变慢了;另一方面是文件太多,很难维护。

怎么办呢?思许良久,发现A表中有个录入时间字段是不会变更的。如果截取录入时间的年份+月份组成,用来创建B目录下的子目录名,把当年当月新增的文件统一归档于该子目录下,不就可以吗?新增的文件好处理,可对于旧文件归档需要费点周折,因为文件得迁移到新的子目录里。

下面是关于文件迁移的主要代码:

  1.  static void Main(string[] args)   
  2. {   
  3.    string paperPath = ConfigurationManager.AppSettings["PaperBuildPath"];   
  4.   Console.WriteLine(string.Format("试卷目录:{0}", paperPath));   
  5.  Console.WriteLine();   
  6.   Console.WriteLine("目录是否正确? 正确请按任意键......");   
  7.   Console.WriteLine();   
  8.  Console.ReadKey();   
  9.   string[] files = Directory.GetFiles(paperPath);   
  10.  int num = 0;   
  11.   PublicExam[] list = Gateway.Default.FindArray<PublicExam>();   
  12.  foreach (PublicExam publicExam in list)   
  13. {   
  14.   foreach (string file in files)   
  15.     {   
  16.       //源文件名(去除路径后)   
  17.       string fileName = file.Split('\\').Last();   
  18.  if (fileName.StartsWith(publicExam.FGuid.ToString(), StringComparison.CurrentCultureIgnoreCase))   
  19.       {   
  20.          //目标文件夹   
  21.          string destFilePath = paperPath + publicExam.FInputTime.ToString("yyyyMM");   
  22.       if (Directory.Exists(destFilePath) == false)   
  23.            Directory.CreateDirectory(destFilePath);   
  24.       //目标文件名   
  25.        string destFileName = destFilePath + "\\" + fileName;   
  26.       if (File.Exists(destFileName))   
  27.           File.Delete(destFileName);   
  28.          Console.WriteLine(string.Format("正在迁移文件:{0}", fileName));   
  29.       //迁移文件   
  30.        File.Move(file, destFileName);   
  31.       num++;   
  32.        }   
  33.      }   
  34.     }   
  35.   Console.WriteLine();   
  36.  Console.WriteLine(string.Format("共迁移{0}个文件,请按任意键退出......", num));   
  37.    Console.ReadKey();   
  38.  }  

上面例子参考了MSDN 关于File Class 和 Directory Class 的使用方法。

执行效果图如下:

Tips:

目录名(年份+月份) 如:201101

c#   => DateTime.Now.ToString("yyyyMM")

SQL => convert(varchar(6),getdate(),112)

当然仅仅文件迁移是不够的,还有很多工作要做,比如修改程序;更新数据库表记录等等。我知道,这次“手术”不符合开放-关闭原则。

原文链接:http://www.cnblogs.com/hailibu/archive/2011/01/05/1926361.html

【编辑推荐】

带您了解Oracle文件系统机制

详解MongoDB实现存储物理文件和SQUID加速

对DB2外部文件格式的阐述

DB2外部文件格式浅析

Oracle数据库文件管理经验谈

 

责任编辑:彭凡 来源: 博客园
相关推荐

2010-04-22 15:34:16

Oracle海量数据

2014-04-30 13:21:06

2014-11-05 16:49:20

初志科技

2011-08-25 16:13:31

SQL Server批量替换数据

2010-04-14 12:38:56

Oracle海量数据

2011-03-28 08:47:46

海量数据库管理中韩数据库专家

2011-05-12 09:19:36

海量数据库管理

2011-08-05 14:31:04

mysql_conve批量转换MYSQL数据MYISAM

2010-04-19 10:50:01

Oracle转移

2011-05-26 13:07:29

数据库切换故障转移

2011-09-01 10:10:56

OceanBase海量淘宝

2011-06-03 09:22:04

OracleOracle应用服务器

2011-09-01 10:54:28

OceanBase数据库海量

2013-04-26 16:18:29

大数据全球技术峰会

2011-03-28 17:07:14

海量数据库

2010-09-13 15:31:14

sql server数

2019-11-22 08:05:01

数据库mysql分区

2011-08-19 13:28:25

海量数据索引优化

2011-08-04 18:00:47

SQLite数据库批量数据

2011-05-26 15:53:59

数据库更新维护
点赞
收藏

51CTO技术栈公众号