Загрузка данных с помощью консольного приложения C # - PullRequest
0 голосов
/ 13 июля 2010

У меня есть консольное приложение C #, которое загружает данные в базу данных SQL Server после небольшого вычисления, которое выполняется с использованием различных функций C #. Теперь проблема в том, что для расчета и загрузки одной строки данных требуется почти 1 секунда, и я должен загрузить 50 000 строк данных таким же образом.

Пожалуйста, предложите мне способ решения этой проблемы.

P.S. Я использую stringbuilder для составления отдельных операторов вставки и загрузки в большом количестве. Этот процесс занимает всего 1 мин.


Вставка или обновление в базе данных вряд ли займет какое-то время, как я уже упоминал в своем вопросе. Расчет занимает большую часть времени. Я прилагаю пример кода функции ниже:

public void EsNoMinLim()

{
        ds = new DataSet();
        ds = getDataSet("select aa.Country, aa.Serial_No from UEM_Data aa inner join (select distinct " +
            "IId, Country from UEM_Data where Active_Status is null) bb on aa.iid = bb.iid where aa.Serial_No <> '0'").Copy();

        execDML("Delete from ProMonSys_Grading");

        StringBuilder strCmd = new StringBuilder();

        foreach (DataRow dRow in ds.Tables[0].Rows)
        {
            SiteCode = dRow["Country"].ToString();
            Serial_No = dRow["Serial_No"].ToString();

            ds_sub = new DataSet();
            ds_sub = getDataSet("select EsNo_Abs_Limit from EsNo_Absolute_Limit where Fec_Coding_Rate in "+
                "(select MODCOD from FEC_Master where NMS_Value in (select Top 1 FEC_Rate from "+
                "DNCC_Billing_Day where Serial_No = '" + Serial_No + "' and [Date] = (select max([Date]) "+
                "from DNCC_Billing_Day where Serial_No = '" + Serial_No + "')))").Copy();

            if (ds_sub.Tables[0].Rows.Count > 0 && Convert.ToString(ds_sub.Tables[0].Rows[0][0]) != "")
            {
                Min_EsNo = Convert.ToString(ds_sub.Tables[0].Rows[0][0]);
            }
            else
            {
                Min_EsNo = "a";
            }

            if (Min_EsNo != "a")
            {
                ds_sub = new DataSet();
                ds_sub = getDataSet("select Top 1 modal_Avg_EsNo from DNCC_Billing_Day where " +
                    "Serial_No = '" + Serial_No + "' and [Date] = (select max([Date]) from DNCC_Billing_Day " +
                    "where Serial_No = '" + Serial_No + "')").Copy();

                if (ds_sub.Tables[0].Rows.Count > 0 && Convert.ToString(ds_sub.Tables[0].Rows[0][0]) != "")
                {
                    Avg_EsNo = Convert.ToString(ds_sub.Tables[0].Rows[0][0]);
                }
                else
                {
                    Avg_EsNo = "-1";
                }

                ds_sub = new DataSet();
                ds_sub = getDataSet("select Top 1 Transmit_Power from ProMonSys_Threshold where Serial_No = '" + Serial_No + "'").Copy();

                if (ds_sub.Tables[0].Rows.Count > 0 && Convert.ToString(ds_sub.Tables[0].Rows[0][0]) != "")
                {
                    Threshold_EsNo = Convert.ToString(ds_sub.Tables[0].Rows[0][0]);
                }
                else
                {
                    Threshold_EsNo = "-1";
                }

                getGrade = EsNoSQFGrading(Min_EsNo, Avg_EsNo, Threshold_EsNo);

                strCmd.Append("insert into ProMonSys_Grading(SiteCode, Serial_No, EsNo_Grade) " +
                            "values('" + SiteCode + "','" + Serial_No + "','" + getGrade + "')");
            }
        }

        execDML_StringBuilder(strCmd);
    }

1 Ответ

0 голосов
/ 13 июля 2010

Узнайте, какая часть процесса является дорогой.Используйте StopWatch, чтобы проверить, сколько времени занимает загрузка, расчет и сохранение.Тогда ты какую часть улучшаешь (и можешь рассказать нам).

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