DataGridView单元格取数判断异常;Fill()速度太慢,请指教!

skyfine 2012-05-28 04:42:02
问题1:我在对"是否加急"进行判断的时候,条件直接跳到for外面了,i++都不执行,也没有产生异常.我把"是否加急"的这个判断注释掉之后,可以进入到循环体.并执行i++....
单步跟踪的时候,我在监视窗口可以输入:

(bool)this.订单生产进度表DataGridView.SelectedRows[0].Cells["是否加急"].Value

可以看到值为false

try
{

this.订单生产进度表DataGridView.SelectAll();
for (int i = 0; i < this.订单生产进度表DataGridView.Rows.Count
&& (bool)this.订单生产进度表DataGridView.SelectedRows[i].Cells["是否完工"].Value == false
&& (bool)this.订单生产进度表DataGridView.SelectedRows[i].Cells["是否加急"].Value == true
; i++)
{
//MessageBox.Show(System.DateTime.Now.ToLongTimeString());
this.订单生产进度表DataGridView.Rows[i].DefaultCellStyle.BackColor = System.Drawing.Color.Yellow;
}
}
catch
{
MessageBox.Show("行:232");
}


请问有什么原因可能造成这种问题?

问题2:
我是通过VS 2010的数据源进行的数据配制,datagridview也是直接从数据源到拖到控件的。现在发现一个性能问题,一张750行68列的表。系统的Fill时间需要近60秒.如果数据达到10000行,不管是更新还是排序都成了一个大问题。有什么在现有基础上的解决方法?

this.订单生产进度表TableAdapter.Fill(this.patersonDataSet.订单生产进度表);
...全文
147 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
skyfine 2012-05-28
  • 打赏
  • 举报
回复
解决了

try
{

//this.订单生产进度表DataGridView.SelectAll();

for (int i = 1; i < this.订单生产进度表DataGridView.Rows.Count; i++)
{
if ((bool)(this.订单生产进度表DataGridView["是否完工", i].Value) == false
&& (bool)this.订单生产进度表DataGridView["是否加急", i].Value == true
)
{
this.订单生产进度表DataGridView.Rows[i].DefaultCellStyle.BackColor = System.Drawing.Color.Yellow;
}
}
}
catch
{
MessageBox.Show("行:232");
}

不知道为什么把if的条件加到for里面之后总是不能正确的执行。
qldsrx 2012-05-28
  • 打赏
  • 举报
回复
(bool)this.订单生产进度表DataGridView.SelectedRows[i].Cells["是否加急"].Value == true
难道这个Value是false?
skyfine 2012-05-28
  • 打赏
  • 举报
回复
没异常抛出,监视窗口有值显示.但却直接跳到了for外面,太郁闷了!
熙风 2012-05-28
  • 打赏
  • 举报
回复
for (int i = 0; i < this.订单生产进度表DataGridView.Rows.Count ; i++)
{
if((bool)this.订单生产进度表DataGridView.Rows[i].Cells["是否完工"].Value== false&&
&& (bool)this.订单生产进度表DataGridView.Rows[i].Cells["是否加急"].Value== True )
{
//MessageBox.Show(System.DateTime.Now.ToLongTimeString());
this.订单生产进度表DataGridView.Rows[i].DefaultCellStyle.BackColor = System.Drawing.Color.Yellow;
}
}


分页解决
qldsrx 2012-05-28
  • 打赏
  • 举报
回复
68列难道都要显示?光光那个滚动条就要拖死人的。你就显示需要的十几个列的话,几百行数据不可能慢的。
bdmh 2012-05-28
  • 打赏
  • 举报
回复
不进入,问题肯定出在那3个条件,for处断点,看看此时的3个条件,另外你为什么用SelectedRows呢,既然都全选了,就用Rows遍历看看

第二个问题,取决于你的网络状况,数据库设计,数据量等,你要做的就是取优化这些问题,比如查询加索引,是否用分页技术,是否需要select * 等
vb.net操作DataGridView控件的用法的集合,包括: 1. DataGridView当前的单元格属性取得、变更 2. DataGridView编辑属性 3. DataGridView最下面一列新追加行非表示 4. DataGridView判断当前选中行是否为新追加的行 5. DataGridView删除行可否设定 6. DataGridView行列不表示和删除 DataGridView控件用法合集(二) 7. DataGridView行列宽度高度设置为不能编辑 8. DataGridView行高列幅自动调整 9. DataGridView指定行列冻结 10. DataGridView列顺序变更可否设定 11. DataGridView行复数选择 12. DataGridView选择的行、列、单元格取得 DataGridView控件用法合集(三) 13. DataGridView指定单元格是否表示 14. DataGridView表头部单元格取得 15. DataGridView表头部单元格文字列设定 16. DataGridView选择的部分拷贝至剪贴板 17.DataGridView粘贴 18. DataGridView单元格上ToolTip表示设定(鼠标移动到相应单元格上时,弹出说明信息) DataGridView控件用法合集(四) 19. DataGridView中的ContextMenuStrip属性 20. DataGridView指定滚动框位置 21. DataGridView手动追加列 22. DataGridView全体分界线样式设置 23. DataGridView根据单元格属性更改显示内容 24. DataGridView新追加行的行高样式设置る 25. DataGridView新追加行单元格默认值设置 DataGridView中输入错误数据的处理(五) 26. DataGridView单元格数据错误标签表示 27. DataGridView单元格内输入值正确性判断 28. DataGridView单元格输入错误值事件的捕获 DataGridView控件用法合集(六) 29. DataGridView行排序(点击列表头自动排序的设置) 30. DataGridView自动行排序(新追加值也会自动排序) 31. DataGridView自动行排序禁止情况下的排序 32. DataGridView指定列指定排序 DataGridView控件用法合集(七) 33. DataGridView单元格样式设置 34. DataGridView文字表示位置的设定 35. DataGridView单元格内文字列换行 36. DataGridView单元格DBNull值表示的设定 37. DataGridView单元格样式格式化 38. DataGridView指定单元格颜色设定 39. DataGridView单元格文字字体设置 40. DataGridView根据单元格值设定单元格样式 DataGridView控件用法合集(八) 41. DataGridView设置单元格背景颜色 42. DataGridView行样式描画 43. DataGridView显示行号 44. DataGridView焦点所在单元格焦点框不显示的设定 DataGridView控件用法合集(九) 45. DataGridView中显示选择框CheckBox 46. DataGridView中显示下拉框ComboBox 47. DataGridView单击打开下拉框 48. DataGridView中显示按钮 49. DataGridView中显示链接 50. DataGridView中显示图像 DataGridView控件用法合集(十) 51. DataGridView编辑中单元格控件取得 52. DataGridView输入自动完成 53. DataGridView单元格编辑时键盘KEY事件取得 54. DataGridView下拉框(ComboBox)单元格编辑时事件取得 55. DataGridView下拉框(ComboBox)单元格允许文字输入设定 DataGridView控件用法合集(十一) 56. DataGridView根据值不同在另一列中显示相应图片 57. DataGridView中显示进度条(ProgressBar) 58. DataGridView中添加MaskedTextBox DataGridView控件用法合集(十二) 59. DataGridView中Enter键按下焦点移至旁边的单元格 60. DataGridView行集合化(Group)

110,536

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Web++
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧