C# asp日历的数据源

C# asp日历的数据源,c#,mysql,asp.net,C#,Mysql,Asp.net,我正在尝试将mysql数据绑定到asp:calendar,但它不起作用。我需要根据date列在mysql表slotavailable列中显示数据。如何将其放入日历单元格中 <asp:Calendar ID="cal2" runat="server" Width="50%" DayField="Date" OnDayRender="Calendar1_DayRender" BackColor="Orange" NextMonthText="Next" PrevMont

我正在尝试将mysql数据绑定到asp:calendar,但它不起作用。我需要根据date列在mysql表slotavailable列中显示数据。如何将其放入日历单元格中

<asp:Calendar ID="cal2" runat="server" Width="50%" DayField="Date" OnDayRender="Calendar1_DayRender"
            BackColor="Orange" NextMonthText="Next" PrevMonthText="Prev" >
            <DayStyle CssClass="days" VerticalAlign="Top" Font-Name="Arial" Height="80px" BackColor="lightYellow"  />
            <TodayDayStyle BackColor="Orange"  />
            <OtherMonthDayStyle BackColor="LightGray" ForeColor="DarkGray"/>
</asp:Calendar>

下面是获取数据的cs代码

 protected void Page_Load(object sender, EventArgs e)
    {
        if (!IsPostBack)
        {
            cal2.VisibleDate = DateTime.Today;
            FillLeaveplannerDataset();
        }
    }
    protected void FillLeaveplannerDataset()
    {
        DateTime firstDate = new DateTime(cal2.VisibleDate.Year, cal2.VisibleDate.Month, 1);
        DateTime lastDate = GetFirstDayOfNextMonth();
        dsleaveplanner = GetCurrentMonthData(firstDate, lastDate);
    }
    protected DateTime GetFirstDayOfNextMonth()
    {
        int monthNumber, yearNumber;
        if (cal2.VisibleDate.Month == 12)
        {
            monthNumber = 1;
            yearNumber = cal2.VisibleDate.Year + 1;
        }
        else
        {
            monthNumber = cal2.VisibleDate.Month + 1;
            yearNumber = cal2.VisibleDate.Year;
        }
        DateTime lastDate = new DateTime(yearNumber, monthNumber, 1);
        return lastDate;
    }
    protected DataSet GetCurrentMonthData(DateTime firstDate, DateTime lastDate)
    {
        DataSet dsMonth = new DataSet();
        MySqlConnection con = new MySqlConnection("Server=localhost;Database=mydb;Uid=myid;Pwd=abc123;");
        MySqlCommand cmd = new MySqlCommand("SELECT * FROM dummy WHERE date >= @firstDate AND date < @lastDate", con);
        cmd.Parameters.Add(new MySqlParameter("@firstDate", firstDate));
        cmd.Parameters.Add(new MySqlParameter("@lastDate", lastDate));
        MySqlDataAdapter mysqlDataAdapter = new MySqlDataAdapter(cmd);
        try
        {
            mysqlDataAdapter.Fill(dsMonth);
        }
        catch { }
        return dsMonth;
    }

protected void Calendar1_DayRender(object sender, DayRenderEventArgs e)
{

    DateTime nextDate;
    if (dsleaveplanner != null)
    {
        foreach (DataRow dr in dsleaveplanner.Tables[0].Rows)
        {
            nextDate = (DateTime)dr["date"];
            var slot = dr["slotavailable"];
            if (nextDate == e.Day.Date)
            {
                e.Cell.BackColor = System.Drawing.Color.Pink;
            }
        }
    }
}
protected void Calendar1_VisibleMonthChanged(object sender,
MonthChangedEventArgs e)
{
    FillLeaveplannerDataset();
}
受保护的无效页面加载(对象发送方,事件参数e)
{
如果(!IsPostBack)
{
cal2.VisibleDate=DateTime.Today;
FillLeaveplannerDataset();
}
}
受保护的空FillLeaveplannerDataset()
{
DateTime firstDate=新的日期时间(cal2.VisibleDate.Year,cal2.VisibleDate.Month,1);
DateTime lastDate=GetFirstDayOfNextMonth();
dsleaveplanner=GetCurrentMonthData(firstDate,lastDate);
}
受保护的DateTime GetFirstDayOfNextMonth()
{
内蒙蒙特诺姆,阿森诺姆;
如果(cal2.VisibleDate.Month==12)
{
月数=1;
DerAnumber=cal2.VisibleDate.Year+1;
}
其他的
{
monthNumber=cal2.VisibleDate.Month+1;
数字=cal2.VisibleDate.Year;
}
DateTime lastDate=新的日期时间(数字,月数,1);
返回最后日期;
}
受保护的数据集GetCurrentMonthData(DateTime firstDate、DateTime lastDate)
{
数据集dsMonth=新数据集();
MySqlConnection con=newmysqlconnection(“Server=localhost;Database=mydb;Uid=myid;Pwd=abc123;”;
MySqlCommand cmd=new MySqlCommand(“从dummy中选择*,其中date>=@firstDate和date<@lastDate”,con);
cmd.Parameters.Add(新的MySqlParameter(“@firstDate”,firstDate));
cmd.Parameters.Add(新的MySqlParameter(“@lastDate”,lastDate));
MySqlDataAdapter MySqlDataAdapter=新的MySqlDataAdapter(cmd);
尝试
{
mysqlDataAdapter.Fill(dsMonth);
}
捕获{}
每月返回一次;
}
受保护的无效日历1\u DayRender(对象发送方,DayRenderReventArgs e)
{
日期时间下一个日期;
if(dsleaveplanner!=null)
{
foreach(dsleaveplanner.Tables[0].Rows中的DataRow dr)
{
下一个日期=(日期时间)dr[“日期”];
var插槽=dr[“插槽可用”];
如果(下一个日期==e.Day.Date)
{
e、 Cell.BackColor=System.Drawing.Color.Pink;
}
}
}
}
受保护的无效日历1\u VisibleMonthChanged(对象发送方,
MonthChangedEventArgs(东)
{
FillLeaveplannerDataset();
}

如何将插槽列数据放入日历单元格?

请确保您的
nextDate
e.Day.Date
匹配,然后更改代码,如

e.Cell.Controls
可以向单元格中添加任何文本

protected void Calendar1_DayRender(object sender, DayRenderEventArgs e)
{

    DateTime nextDate;
    if (dsleaveplanner != null)
    {
        foreach (DataRow dr in dsleaveplanner.Tables[0].Rows)
        {
            nextDate = (DateTime)dr["date"];
            var slot = dr["slotavailable"];
            if (nextDate == e.Day.Date)
            {
                //This is the line where we add slotavailable column data
                e.Cell.Controls.Add(new LiteralControl($"<p>{slot}</p>"));
                e.Cell.BackColor = System.Drawing.Color.Pink;
            }
        }
    }
}
受保护的无效日历1\u DayRender(对象发送方,DayRenderReventArgs e)
{
日期时间下一个日期;
if(dsleaveplanner!=null)
{
foreach(dsleaveplanner.Tables[0].Rows中的DataRow dr)
{
下一个日期=(日期时间)dr[“日期”];
var插槽=dr[“插槽可用”];
如果(下一个日期==e.Day.Date)
{
//这是我们添加slotavailable列数据的行
e、 Cell.Controls.Add(新的LiteralControl($“{slot}

”); e、 Cell.BackColor=System.Drawing.Color.Pink; } } } }
输出将是

e.Cell.控件的优点
您可以根据需要添加html
按钮
span
图像
或任何其他内容

e.Cell.Controls.Clear()可以帮助您清除与特定单元格相关的所有控件


请再试一次,它可能会帮助您

我发现了错误,它只会更改表中日期的颜色。有人能帮我添加文本和阅读slotavailable列吗?您的
dsleaveplanner
firstDate
lastDate
之间是否有正确的数据?是的,它甚至会更改中日期的颜色datatable@prkash,如果答案有助于您接受并投票赞成,我也投票赞成您的问题:)我现在有一个不同的问题,当我单击任何日期或表单上的提交按钮时,数据和标签消失,请让我检查并测试一次:)从我这边看,无论数据集如何,工作正常,请在回发后检查您的数据集是否已填充,可能是您的数据集在回发时为空您的意思是我应该在onselectionchanged事件中添加FillLeaveplannerDataset()?你能解释一下吗?我的代码和上面显示的完全一样,包括你的答案。如果你不介意的话,请把你的密码贴出来好吗?