不包含适用于入口点的静态main方法(但我已正确配置)

时间:2015-06-10 21:06:12

标签: c# sql main-method

大家好朋友我有一个控制台应用程序,从访问数据库更新三个表中读取数据,我使用一个名为automate 9.0的软件进行自动化,所以我需要知道exe是否失败以及为什么它失败所以我跟踪一些枚举值,我认为这会导致我的主要方法出错。

namespace accessmovingtest
   {
     enum ExitCode : int
      {
       Success = 0,
       SqlError = 1,
       CannotFindFileAccessDB = 2,
       ConnectionRelatedError = 3
      }
   class Program
    {
        public static ExitCode Main(string[] args) 
        {
            ExitCode RetVal;
            string accdbConnStr = ConfigurationManager.ConnectionStrings["AccessDBtoSql.Properties.Settings.Company_Master_DataConnectionString"].ToString();
    var con = new OdbcConnection(accdbConnStr);
     try
      { 
        con.Open();
        con.Close();
      }
      catch(Exception ex)
       {
          Console.Out.WriteLine(ex.StackTrace);
          Console.Out.WriteLine(ex.Message);
          Console.Out.WriteLine(ex.TargetSite);
          Console.WriteLine("Cannot Establish a connection to the access database");
                RetVal = ExitCode.ConnectionRelatedError;
                return RetVal;
            }

            try
            {
                string accdbConnStrr = ConfigurationManager.ConnectionStrings["AccessDBtoSql.Properties.Settings.Company_Master_DataConnectionString"].ToString();
                if (!File.Exists(accdbConnStrr))
                {
                    Console.WriteLine("AccessDb Found");
                }
            }
            catch (FileNotFoundException ex)
            {

                Console.Out.WriteLine(ex.StackTrace);
                Console.Out.WriteLine(ex.Message);
                Console.WriteLine("Cannot Find Access Data");
                RetVal = ExitCode.CannotFindFileAccessDB;
                return RetVal;

            }
            catch (Exception ex)
            {
                Console.Out.WriteLine(ex.Message);
            }

            try
            {
                accesstosqlitemmaster();


            }
            catch (Exception ex)
            {
                Console.Out.WriteLine(ex.StackTrace);
                Console.Out.WriteLine(ex.Message);
                RetVal = ExitCode.SqlError;
                return RetVal;


            }
            try
            {
                accesstosqlpiecedimensionmasterdata();

            }
            catch (Exception ex)
            {
                Console.Out.WriteLine(ex.StackTrace);
                Console.Out.WriteLine(ex.Message);
                RetVal = ExitCode.SqlError;
                return RetVal;

            }
            try
            {
                accesstosqlitemdeslookups();


            }
            catch (Exception ex)
            {
                Console.Out.WriteLine(ex.StackTrace);
                Console.Out.WriteLine(ex.Message);
                RetVal = ExitCode.SqlError;
                return RetVal;
            }
            RetVal = ExitCode.Success;
            return RetVal;


        }

在主要方法旁边的ExitCode上获取错误

1 个答案:

答案 0 :(得分:2)

根据C#5.0语言规范,§3.1,

  

应用程序启动在执行环境调用时发生   指定的方法,称为应用程序的条目   点。此入口点方法始终命名为Main,并且可以有一个   以下签名:

     

static void Main() {...}

     

static void Main(string[] args) {...}

     

static int Main() {...}

     

static int Main(string[] args) {...}

你正在为你的main方法返回一个枚举,而不是那个满足规范的enum底层的int。

public static int Main(string[] args) 
{
    ExitCode RetVal;
    ...
    ...
    RetVal = ExitCode.Success;
    return (int)RetVal;