Выдает запросы к базе данных - работает только на моем ПК - PullRequest
1 голос
/ 14 декабря 2011

Я написал некоторый код, который должен добавить ответ базы данных в список.он работает на моем ПК, но не работает при развертывании моей программы на другом ПК.Я придавил свой метод.Он перестает работать, когда он нажимает

int tot = rs.Fields.Count;

Вот мой код:

        public static List<List<String>> QUERY(String query, String dbPath)
    {   ADODB.Connection cn = new ADODB.Connection();
        ADODB.Recordset rs = new ADODB.Recordset();            ADODB.Command cmdSQLData = new ADODB.Command();
        List<List<String>> RETURNME = new List<List<String>>();
        string cnStrOld = "Driver={Microsoft Access Driver (*.mdb)}; Dbq=" + dbPath + ";Uid=;Pwd=;"; //does not work
        string  cnStr = @"Provider=Microsoft.JET.OLEDB.4.0; data source=" + dbPath;
            cn.ConnectionTimeout = 0;
            cn.Open(cnStr);
            cn.CommandTimeout = 0;
            rs.Open(query, cn);
        while (rs.EOF == false) //GET HEADERNAMES, ADD TO LIST
        {
            List<String> A = new List<string>();
            int tot = rs.Fields.Count;// calculating the amount of columns in the RS
            for (int i = 0; i < tot; i++) //iterating through all columns and checking it's name
            {
                A.Add(rs.Fields[i].Name.ToString());
            }
            RETURNME.Add(A);
            break;
        }
        while (rs.EOF == false)//GET DATA, ADD TO LIST
        {
            List<String> B = new List<string>(); //list of Data
            int tot = rs.Fields.Count;// calculating the amount of columns in the RS
            //Now we add query response
            for (int i = 0; i < tot; i++) //iterating through all columns and checking it's name
            {
                B.Add(rs.Fields[i].Value.ToString());
            }
            RETURNME.Add(B);
            rs.MoveNext();
        }
            rs.Close();
            cn.Close();
        return RETURNME;
    }

Я использую относительные пути, и они проверены ОК.У меня также есть свои пробные уловки (я удалил их отсюда, чтобы уменьшить код), и они не указывают на ошибки.Каким-то образом программа способна войти в оператор while (rs.EOF == false), поэтому я предполагаю, что записи возвращены?

Не могли бы вы помочь?


Я получил следующее решение:

        public static List<List<String>> QUERY_TEST(String query, String dbPath)
    {

        List<List<String>> RETURNME = new List<List<String>>();
        String cnStr = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + dbPath + ";Jet OLEDB:Database Password=;";
        OleDbDataAdapter Data1 = new OleDbDataAdapter(query, cnStr);

        DataSet a = new DataSet();
        Data1.Fill(a);
        DataTable dt = a.Tables[0];

        //Adding column names to the first row on the list
        List<String> B = new List<string>();
        foreach (DataColumn dr in dt.Columns)
        {
            List<String> A = new List<string>();
            B.Add(dr.Caption.ToString());
        }
        RETURNME.Add(B);

        //Adding data to the columns
        foreach (DataRow dr in dt.Rows)
        {
            List<String> A = new List<string>();
            for (int i = 0; i < dt.Columns.Count; i++)
            {
                A.Add(dr[i].ToString());
            }
            RETURNME.Add(A);
            break;
        }
        return RETURNME;
    }

Ответы [ 4 ]

2 голосов
/ 14 декабря 2011

Убедитесь, что путь доступен с удаленного компьютера (например, на удаленном компьютере или в каком-либо сетевом ресурсе) и доступен пользователю, который запускает программу.

1 голос
/ 15 декабря 2011

в основном это то, что вы могли бы сделать .. конечно, вам нужно заменить некоторые вещи на имена переменных, где это необходимо

public static List<string> QUERY(string query, string dbpath)
{
   string  cnStr = @"Provider=Microsoft.JET.OLEDB.4.0; data source=" + dbPath;
   oleconn = new OleDbConnection(cnStr);
   List<string>lstColumns = null;
   string[] strarryColumnNames = {}; //keep this just like this it's how you can declare dynamic array
   string strCommaDelimColumns = string.Empty;
   OleDbDataReader drdrRecord = null;
   OleDbConnection oleconn = null;

   using(OleDbCommand  olecmd new OleDbCommand(query, cnStr))
   {
        olecmd.CommandTimeout = 60;
        olecmd.CommandType = System.Data.CommandType.Text;  
        oleconn.Open();
        //if you want to get the record count just setup a query with Select (count) as recCnt .... 
        //do the oledrd execute here.. then call oledrdr.Close(); and assign the other query string to another execute reader
        /* basically do something like this and replace what I have with what you need
            var drdrRecordCntReader = olecmd.ExecuteReader();
            oledrdr.Read();
            intRecCount = (int)oledrdr[recCnt];//value returned from the Select Count(*)
            if (intRecCount == 0)
            {
                return false;
            }//if (intRecCount == 0)        
        */
        oledrdr = olecmd.ExecuteReader();
        lstColumns = new List<string>();
        //load the field header contents here 
        for (int intCounter = 0; intCounter < oledrdr.FieldCount; intCounter++)
        {
          lstColumns.Add(oledrdr.GetName(intCounter));
        }       
        strarrayColumnNames = lstColumns.ToArray();     
        strCommaDelimColumns = string.Join(",", strarryColumnNames);
        //use the same lstColumns to add the data no need for a second while loop
        //close the reader oledrdr
        //use it again
        try
        {
             //outter loop - Read row record by record 
            for (int intCounter = 0; intCounter < intRecCount - 1; intCounter++) // figure out how to get record count
            {
               rdrDataReader.Read();
             //inner loop - read each field data within that row
                 for (int intFieldcnt = 0; intFieldcnt < intColumnCnt; intFieldcnt++)
                 {
                    //put your field data value code here
                 }//for (int intFieldcnt = 0; intFieldcnt < intColumnCnt; intFieldcnt++)
             }
         }
         catch (Exception ex)
         {

         }
    }           
}
1 голос
/ 14 декабря 2011

Попробуйте следующее:
Объявите список B перед вашей первой группой.Затем добавьте первый элемент B в первую группу while в цикле for.В завершение перед выходом из первой группы while добавьте rs.MoveNext ();

1 голос
/ 14 декабря 2011

проблемы заключается в изменении строки подключения или проверьте строку подключения, используя вместо этого

strAccessConnectionString="Provider=Microsoft.Jet.OLEDB.4.0;Data Source=\\yourpath\+yourAccessDataBase.mdb;Jet OLEDB:Database Password=if you have a password put here;"
...