I’m dynamically adding rows to a datagridview this way:
Question question = new Question();
List<Question> questions = question.GetQuestionsByQuestionnaire(questionnaireId);
if (questions != null)
{
dgvQuestions.Columns.Add("Question", "Vraag");
dgvQuestions.Columns.Add("QuestionType", "Vraag type");
dgvQuestions.Columns.Add("Category", "Categorie");
for (int i = 0; i < questions.Count; i++ )
{
int row = dgvQuestions.Rows.Add();
dgvQuestions.Rows[row].Cells["Question"].Value = questions[i].Question;
dgvQuestions.Rows[row].Cells["QuestionType"].Value = questions[i].QuestionType;
dgvQuestions.Rows[row].Cells["Category"].Value = questions[i].Category;
dgvQuestions.Rows[row].Tag = questions[i];
}
}
I don’t get any errors, but the cell value stays null and I’m 100% sure that Question, QuestionType and Category contains data. What am i missing here?
I’m not sure about why this is the case, but I’d go for a mix of dynamic data but typed dataset.
What you’d do is:
DataSet, add a “Questions” table with the columns you needDataSetfrom the Toolbox on your form (must recompile before that), name it for examplemyDataSource.BindingSourceon your form, assign themyDataSourceto theDataSourceproperty and select your table for theDataMemberproperty.DataSourceproperty of yourDataGridViewAdd data to the data source by using for example
myDataSource.Questions.NewQuestionsRow()andmyDataSource.Questions.AddQuestionsRow(...).