减少日历上的加载时间
本文关键字:加载 时间 日历 | 更新日期: 2023-09-27 18:36:17
下面你看到我的网站日历的代码,问题是这段代码大约需要 8-10 秒才能加载。如果你们中的任何人能看到一种最小化加载时间的方法,我将不胜感激。
public static IEnumerable<DateTime> AllDatesInMonth(int year, int month)
{
foreach (var day in Enumerable.Range(1, DateTime.DaysInMonth(year, month)))
{
yield return new DateTime(year, month, day);
}
}
public void ForeachDayInMonth(int year, int month, SqlConnection connection)
{
int day;
int count;
double divHeight;
lbl_Month.Text += "<table class='"Month'">";
foreach (DateTime date in AllDatesInMonth(year, month))
{
day = int.Parse(date.ToString().Substring(0, 2));
count = Begivenheder.Get_Begivenhed_By_Date(year, month, day, connection).Count; // Creates a sql select statement
lbl_Month.Text += "<tr>" +
"<td style='"height: 30px; width: 70px;";
if (date.Date == DateTime.Today)
{
lbl_Month.Text += "-webkit-box-shadow:inset 0px 0px 20px rgba(000,000,000,0.8);" +
"-moz-box-shadow:inset 0px 0px 20px rgba(000,000,000,0.8);" +
"box-shadow:inset 0px 0px 20px rgba(000,000,000,0.8);";
}
lbl_Month.Text += "'">";
if (count != 0)
{
divHeight = 100 / count;
foreach (Begivenheder b in Begivenheder.Get_Begivenhed_By_Date(year, month, day, connection)) // creates a sql select statement
{
lbl_Month.Text += "<div style='"background-color: " + b.begivenhed.type.TypeFarve + "; height: " + divHeight + "%;'">" +
"<a href='"KalenderEvent.aspx?Event=" + b.begivenhed.ID + "'">";
if (b.begivenhed.Navn.Length > 9)
{
lbl_Month.Text += b.begivenhed.Navn.Remove(9) + "...";
}
else
{
lbl_Month.Text += b.begivenhed.Navn;
}
lbl_Month.Text += "</a>" +
"</div>";
}
}
lbl_Month.Text += "</td>" +
"</tr>";
}
lbl_Month.Text += "</table>";
}
protected void Page_Load(object sender, EventArgs e)
{
string year;
if (Request.QueryString["Year"] == null)
{
year = DateTime.Today.Year.ToString();
}
else
{
year = Request.QueryString["Year"];
}
Page.Title += " - Kalender " + year;
SqlConnection connection = new SqlConnection(ConfigurationManager.AppSettings["Database"]);
connection.Open();
try
{
Year(int.Parse(year), connection);
}
finally
{
connection.Close();
}
}
private void Year(int year, SqlConnection connection)
{
string thisYear = year.ToString();
int lastYear = year - 1;
int nextYear = year + 1;
lbl_Year.Text = "<div>" +
"<a href='"Kalender.aspx?Year=" + lastYear.ToString() + "'" id='"LastYear'"></a>" +
"</div>" +
"<div>" +
thisYear +
"</div>" +
"<div>" +
"<a href='"Kalender.aspx?Year=" + nextYear.ToString() + "'" id='"NextYear'"></a>" +
"</div>";
lbl_Month.Text = "<table>" +
"<tr>" +
"<td>";
// Dage
lbl_Month.Text += "<p>" +
"</p>" +
"<br />" +
"<table>";
for (int i = 1; i <= 31; i++)
{
lbl_Month.Text += "<tr>" +
"<td style='"height: 30px;'">" +
"<p>" +
i.ToString() +
"</p>" +
"</td>" +
"</tr>";
}
lbl_Month.Text += "</table>" +
"</td>";
//Januar (repeats 12 times, ones for each month)
lbl_Month.Text += "<td>" +
"<p>" +
"Januar" +
"</p>";
ForeachDayInMonth(int.Parse(thisYear), 1, connection);
lbl_Month.Text += "</td>";
lbl_Month.Text += "</tr>" +
"</table>";
}
这是"Begivenheder.Get_Begivenhed_By_Date"代码。
public static List<Begivenheder> Get_Begivenhed_By_Date(int år, int måned, int dag, SqlConnection connection)
{
List<Begivenheder> result = new List<Begivenheder>();
using (var command = new SqlCommand("Select ID, FK_Begivenhed_ID from Begivenhed_Datoer where Dag=" + dag + " and Måned=" + måned + " and År=" + år, connection))
{
SqlDataReader reader = command.ExecuteReader();
try
{
while (reader.Read())
{
Begivenheder b = new Begivenheder();
b.Dato_ID = reader.GetInt32(0);
b.ID = reader.GetInt32(1);
b.Dato_Day = dag;
b.Dato_Month = måned;
b.Dato_Year = år;
result.Add(b);
}
}
finally
{
reader.Close();
}
foreach (Begivenheder b in result)
{
b.begivenhed = Begivenheder.Get_Begivenhed_By_ID(b.ID, connection);
}
}
return result;
}
我知道这是一堆代码,但我不知道如何减少它。
每page_load都会导致 cca 30 数据库查询 - 这是很多开销,请尝试对其进行改造,以便您只需要与数据库对话一次(如果有的话)。除此之外,获取 .NET 探查器并查看您花费最多时间的地方。
您可以通过获取整个间隔的所有事件来提高性能,而不是为每个日期执行一个查询。鉴于您当前的数据模型,您似乎希望在一个月内完成所有事件,这是一个简单的更改。
如果选择每天执行一个查询,请通过向其添加SqlParameters
来重用相同的SqlCommand
,而不是重新生成全新的查询 28-31 次。
基本的字符串优化将产生很大的不同。在必须string +=
的地方,请改用字符串生成器。然后,当所有计算完成后,将 StringBuilder 转换为带有 .ToString() 方法。
请参阅 MSDN 字符串生成器类
同时将string + string + string
代码替换为 AppendFormat 方法
1)使用:
day = date.Day;
而不是:
day = int.Parse(date.ToString().Substring(0, 2));
2)把这个长样式放到样式表/CSS中,改用一个短类='name':
webkit-box-shadow:inset 0px 0px 20px rgba(000,000,000,0.8);" +
"-moz-box-shadow:inset 0px 0px 20px rgba(000,000,000,0.8);" +
"box-shadow:inset 0px 0px 20px rgba(000,000,000,0.8);
3)您每天给Begivenhed_By_Date打电话两次:
1) count = Begivenheder.Get_Begivenhed_By_Date(year, month, day, connection).Count;
2) foreach (Begivenheder b in Begivenheder.Get_Begivenhed_By_Date(year, month, day, connection))
could be:
+) List<Begivenheder> hedByDate = Begivenheder.Get_Begivenhed_By_Date(year, month, day, connection);
1.x count = hedByDate.Count;
2.x foreach (Begivenheder b in hedByDate, connection))
4)至少使用StringBuilder先连接lbl_Month.Text +=字符串,然后最后分配它。
5)研究使用中继器控件,这样你就不必像这样用HTML乱扔代码。
6)更改它,以便只执行一次SQL查询,而不是多次。