Календарь в DataGrid - PullRequest
       12

Календарь в DataGrid

1 голос
/ 02 августа 2011

Я действительно не могу понять, что мне нужно для выполнения моей задачи.У меня есть DataGrid в asp.net в VS2010, он отображает данные из базы данных SQL, в одном из этих полей есть «StartDate».

Также у меня работает простой календарь.Я хотел бы иметь возможность обновлять свою DataGrid, передавая ей выбранную дату и используя ее в качестве «StartDate» для вызова выбора в DataGrid, поэтому будут отображаться только записи с этой датой начала.

Я посмотрел онлайн, но примеры очень старые или немного запутанные.

Если кто-то может расположить шаги (если возможно, пример кода) для достижения этой цели, я был бы признателен или любые ресурсы или примеры, которые вы столкнулись, хотя я искал некоторое время, следовательно, пост !.

Спасибо.

Что у меня сейчас есть

   protected void Page_Load(object sender, EventArgs e)
    {
        if (!IsPostBack)
        {

            Calendar1.VisibleDate = DateTime.Today;
            strConn = @"Data Source=PC88;Initial Catalog=Bookings;Integrated Security=True";    
            mycn = new SqlConnection(strConn);
            myda = new SqlDataAdapter("Select * FROM Bookings", mycn);
            myda.Fill(ds, "Table");
        }
        else 
        {
           // CalendarChange();
            Calendar1.VisibleDate = DateTime.Today;
            strConn = @"Data Source=PC88;Initial Catalog=Bookings;Integrated Security=True";    
            mycn = new SqlConnection(strConn);
            myda = new SqlDataAdapter("Select * FROM Bookings", mycn);
            myda.Fill(ds, "Table");

        }

    }

    protected void CalendarDRender(object sender, System.Web.UI.WebControls.DayRenderEventArgs e)
    {
        // If the month is CurrentMonth
        if (!e.Day.IsOtherMonth)
        {
            foreach (DataRow dr in ds.Tables[0].Rows)
            {
                if ((dr["Start"].ToString() != DBNull.Value.ToString()))
                {
                    DateTime dtEvent = (DateTime)dr["Start"];
                    if (dtEvent.Equals(e.Day.Date))
                    {
                        e.Cell.BackColor = Color.PaleVioletRed;
                    }
                }
            }
        }
        //If the month is not CurrentMonth then hide the Dates
        else
        {
        e.Cell.Text = "";
        }
        }


        private void Calendar1_SelectionChanged(object sender, System.EventArgs e)
        {
        myda = new SqlDataAdapter("Select * from Bookings where Start ='" + Calendar1.SelectedDate.ToString() + "'", mycn);
        dsSelDate = new DataSet();
        myda.Fill(dsSelDate, "AllTables");
        if (dsSelDate.Tables[0].Rows.Count == 0 )
        {
        GridView1.Visible = false;
        }
        else
        {
        GridView1.Visible = true;
        GridView1.DataSource = dsSelDate;
        GridView1.DataBind (); 
        }
      } 
    }

Что я делаю не так ?.

РЕДАКТИРОВАТЬ __

Наконец, это работает, вот мой код, если у кого-то есть аналогичные проблемы / требования.

   protected void Page_Load(object sender, EventArgs e)
    {
        if (!IsPostBack)
        {
            if (!IsPostBack)
            {

                Calendar1.VisibleDate = DateTime.Today;
                strConn = @"Data Source=BBC-PC-S054683;Initial Catalog=Bookings;Integrated Security=True";
                mycn = new SqlConnection(strConn);
                myda = new SqlDataAdapter("Select * FROM Bookings", mycn);
                myda.Fill(ds, "Table");

            }
            else
            { // CalendarChange();
                Calendar1.VisibleDate = DateTime.Today;
                strConn = @"Data Source=PC-Name;Initial Catalog=Bookings;Integrated Security=True";
                mycn = new SqlConnection(strConn);
                myda = new SqlDataAdapter("Select * FROM Bookings", mycn);
                myda.Fill(ds, "Table");

            }

            BindGrid();
        }
    }
    private DataTable GetRecords()
    {
        SqlConnection conn = new SqlConnection(strConnection);
        conn.Open();
        SqlCommand cmd = new SqlCommand();
        cmd.Connection = conn;
        cmd.CommandType = CommandType.Text;
        cmd.CommandText = "Select * from Bookings";
        SqlDataAdapter dAdapter = new SqlDataAdapter();
        dAdapter.SelectCommand = cmd;
        DataSet objDs = new DataSet();
        dAdapter.Fill(objDs);
        return objDs.Tables[0];


    }

    public void Calendar1_SelectionChanged(object sender, System.EventArgs e)
    {

        String Date = Calendar1.SelectedDate.ToLongDateString();
        SqlConnection con = new SqlConnection(strConnection);//put connection string here
        SqlCommand objCommand = new SqlCommand("SELECT * FROM Bookings where Date = '" + Date + "'", con);//let MyTable be a database table
        con.Open();
        SqlDataReader dr = objCommand.ExecuteReader(); 

        GridView.DataSource = dr;
        GridView.DataBind();



                    }

1 Ответ

2 голосов
/ 02 августа 2011

Вам необходимо отфильтровать DataGridView.

try
{
    myDataSet = new DataSet();
    myDataSet.CaseSensitive = true;

    DataAdapter.SelectCommand.Connection = myConnection;
    DataAdapter.TableMappings.Clear();
    DataAdapter.TableMappings.Add("Table", "TableName");
    DataAdapter.Fill(myDataSet);

    myDataView = new DataView(myDataSet.Tables["TableName"], "TIMESTAMP >= '" + 
    Convert.ToDateTime(fromDate) + "' AND TIMESTAMP <= '" + 
    Convert.ToDateTime(toDate) + "'", "TIMESTAMP", DataViewRowState.CurrentRows);

    dgv.DataSource = myDataView;
}
catch (Exception ex)
{
    MessageBox.Show(ex.Message);
}

TIMESTAMP - это столбец в моем DataGridView. Примечание: это всего лишь фрагмент кода!

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