Запрос между двумя датами из Excel с использованием C #, но проблема в том, что я получаю неправильные даты в результате - PullRequest
2 голосов
/ 19 марта 2019

Ниже мой код.Я получаю свои даты от двух DatePicker с в форме Windows.Я пытаюсь получить строки в Excel, которые находятся между этими двумя датами и делают SqlBulkCopy для SQL Server.В результате я получаю неправильные даты.

Я пытался использовать TextBox вместо DatePicker, но это тоже не работает.

using (SqlConnection strConnection = new SqlConnection(Connection))
{
    using (OleDbConnection excelConnection = new OleDbConnection(excelConnString))
    {
        var buttons = (new[] { groupBox1 }
            .SelectMany(g => g.Controls.OfType<RadioButton>()
            .Where(r => r.Checked)))
            .ToList();

        SqlCommand query = new SqlCommand();

        if (buttons[0].Text == "Date Range")
        {
            query.CommandText = "Select * from [Sheet0$]  where [ChangedDate] between @date1 and @date2;";
        }
        else
        {
            query.CommandText = "Select * from [Sheet0$]";
        }

        //Create OleDbCommand to fetch data from Excel
        using (OleDbCommand cmd = new OleDbCommand(query.CommandText, excelConnection))
        {
            if (buttons[0].Text == "Date Range")
            {
                string fromDate = this.fromDate.Value.Date.ToString("MM/dd/yyyy");
                string toDate = this.toDate.Value.Date.ToString("MM/dd/yyyy");                                   
                cmd.Parameters.AddWithValue("@date1", fromDate);
                cmd.Parameters.AddWithValue("@date2", toDate);
            }                               

            excelConnection.Open();
            using (OleDbDataReader dReader = cmd.ExecuteReader())
            {                
                using (SqlBulkCopy sqlBulk = new SqlBulkCopy(strConnection, SqlBulkCopyOptions.TableLock |
                    SqlBulkCopyOptions.FireTriggers |
                    SqlBulkCopyOptions.UseInternalTransaction,
                    null))
                {
                    e.Result = 0;
                    sqlBulk.DestinationTableName = "tblCMHC";

                    while (dReader.Read())
                    {                        
                        sqlBulk.WriteToServer(dReader);
                    }
                }
            }
        }
    }
}

1 Ответ

2 голосов
/ 20 марта 2019

Я нашел ответ.Проблема была не с моим кодом.Фактически я получал правильные результаты поиска из Excel, но мне нужно было изменить формат столбца даты в Excel, чтобы иметь возможность вставлять записи в базу данных сервера SQL в приемлемом формате.

...