ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

c#-从MS Access数据库中提取源代码

2019-12-10 21:09:20  阅读:268  来源: 互联网

标签:version-control c ms-access pia


我有一个Access DB,我想从中提取源代码,以便可以将其放入Source Control中.

我试图使用主互操作程序集(PIA)提取数据,但是由于它没有拾取所有模块和表单,所以出现了问题.

代码中有140个表单和模块(不用问,这是我继承的旧系统),但PIA代码仅能选择其中的91个.

这是我正在使用的代码.

using System;
using Microsoft.Office.Interop.Access;

namespace GetAccesSourceFiles
{
    class Program
    {
        static void Main(string[] args)
        {
            ApplicationClass appClass = new ApplicationClass();
            try
            {
                appClass.OpenCurrentDatabase("C:\\svn\\projects\\db.mdb",false,"");

                Console.WriteLine(appClass.Version);
                Console.WriteLine(appClass.Modules.Count.ToString());
                Console.WriteLine(appClass.Modules.Parent.ToString());

                int NumOfLines = 0;
                for (int i = 0; i < appClass.Modules.Count; i++)
                {
                    Console.WriteLine(appClass.Modules[i].Name + " : " + appClass.Modules[i].CountOfLines);
                    NumOfLines += appClass.Modules[i].CountOfLines;
                }

                Console.WriteLine("Number of Lines : " + NumOfLines);
                Console.ReadKey();
            }
            catch(Exception ex)
            {
                Console.WriteLine(ex.Message + "\r\n" +ex.StackTrace);
            }
            finally
            {
                appClass.CloseCurrentDatabase();
                appClass.Quit(AcQuitOption.acQuitSaveNone);
            }

        }
    }
}

关于该代码可能缺少的任何建议?还是在某个产品/工具上可以帮到我?

编辑:
我还应该提到,这需要脚本到磁盘,与VSS的集成不是一种选择,因为我们的源系统是SVN.谢谢.

解决方法:

有个更好的方法.您可以使用Visual Sourcesafe(以及可能的其他SCC)对控制代码和对象进行版本控制:请参阅此MSDN article

标签:version-control,c,ms-access,pia
来源: https://codeday.me/bug/20191210/2104106.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有