gpt4 book ai didi

c# - 使用 c# 在 excel 的两个日期之间查询,但问题是我得到了错误的日期作为结果

转载 作者:行者123 更新时间:2023-11-30 22:55:26 27 4
gpt4 key购买 nike

下面是我的代码。我从 Windows 窗体中的两个 DatePicker 获取日期。我正在尝试获取 Excel 中这两个日期之间的行,并对 SQL Server 执行 SqlBulkCopy。结果我得到了错误的日期。

我试过使用 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);
}
}
}
}
}
}

最佳答案

我找到了答案。问题不在于我的代码。事实上,我从 excel 中获得了正确的搜索结果,但我需要更改 excel 中日期列的格式,以便能够以可接受的格式将记录插入到 SQL Server 数据库中。

关于c# - 使用 c# 在 excel 的两个日期之间查询,但问题是我得到了错误的日期作为结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55249052/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com