当前位置:七道奇文章资讯数据防范MSSQL防范
日期:2011-01-25 23:11:00  来源:本站整理

数据库中海量文件的批量转移办法[MSSQL防范]

赞助商链接



  本文“数据库中海量文件的批量转移办法[MSSQL防范]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:

事情的经过是这模样的!数据库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)

当然仅仅文件迁移是不够的,还有很多工作要做,比方改正程序;更新数据库表记录等等.我知道,这次“手术”不符合开放-关闭原则.   以上是“数据库中海量文件的批量转移办法[MSSQL防范]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:

  • SQLServer顶用T—SQL号令查询一个数据库中有哪些表的sql语句
  • 设置SQLServer数据库中某些表为只读的多种办法分享
  • sql语句查询数据库中的表名/列名/主键/自动增长值实例
  • 从VS 2010自带的2008 SQL数据库中的数据导入到SQL 2005中
  • 数据库中数据列转行并均分显示
  • Oracle数据库中主要配置文件的经典解析
  • Oracle 9i数据库中动态重配置深化解析
  • VB与Oracle数据库中的日期转换
  • 在MySQL数据库中利用C履行SQL语句
  • 在MySQL数据库中履行SQL语句时的几个注意点
  • 若何将数据库中被锁表解锁
  • 删除数据库中反复数据的几个办法
  • 本文地址: 与您的QQ/BBS好友分享!
    • 好的评价 如果您觉得此文章好,就请您
        0%(0)
    • 差的评价 如果您觉得此文章差,就请您
        0%(0)

    文章评论评论内容只代表网友观点,与本站立场无关!

       评论摘要(共 0 条,得分 0 分,平均 0 分) 查看完整评论
    Copyright © 2020-2022 www.xiamiku.com. All Rights Reserved .