写一个小程序,将数据库中的两张表相关信息显示在DataGridView中。代码如下:

 //获取项目数据,添加到表中
SqlConnection con = new SqlConnection(MainForm2.connection);
con.Open();
string cmd1 = string.Format(@"Select * from ProjectInfo where ProjectName='{0}'", pjnm);
string cmd2 = string.Format(@"Select * from ParameterInfo where ProjectName='{0}'", pjnm);
//添加基本信息表
SqlCommand cmd = new SqlCommand(cmd1,con);
SqlDataReader reader = cmd.ExecuteReader();
reader.Read();
for (int i = ; i < reader.FieldCount; i++)
{
this.dataGridViewX1.Rows.Add();
this.dataGridViewX1[, i].Value = reader.GetName(i);
if (reader.GetValue(i) == null)
{
this.dataGridViewX1[, i].Value = "未输入";
}
else
{
this.dataGridViewX1[, i].Value = reader.GetValue(i).ToString();
}
} int fcount = reader.FieldCount;
reader.Close(); //添加参数信息
SqlCommand cmdd = new SqlCommand(cmd2, con);
reader = cmdd.ExecuteReader();
reader.Read(); for (int i = ; i < reader.FieldCount; i++)
{
this.dataGridViewX1.Rows.Add();
string str = ParameterInfoCls.standardName(i);
this.dataGridViewX1[, fcount + i].Value = str;
if (reader.GetValue(i) == null || reader.GetValue(i).ToString() == "")
{
this.dataGridViewX1[, fcount + i].Value = "未输入";
}
else
{
this.dataGridViewX1[, fcount + i].Value = reader.GetValue(i).ToString();
}
}
reader.Close(); con.Close();

运行后一直出现空白。如图:

第一张表添加正常,第二张表却一直出现空白。断点逐步检查,每行代码值都是正常,且各字段的长度都是很大,数据远没有超出长度。

多次试验发现,第二张表循环错误。由于第二张表与第一张表的第一个字段一样,所以为了剔除该行,循环变量初值为1。对DataGridView单元格赋值时,忘记对该初值减去1,造成

在每次循环中添加第i行,而对第i+1行单元格赋值的情况。

修正循环变量初值,即可。代码如下:

for (int i = ; i < reader.FieldCount; i++)
{
this.dataGridViewX1.Rows.Add();
string str = ParameterInfoCls.standardName(i);
this.dataGridViewX1[, fcount + i-].Value = str;
if (reader.GetValue(i) == null || reader.GetValue(i).ToString() == "")
{
this.dataGridViewX1[, fcount + i-].Value = "未输入";
}
else
{
this.dataGridViewX1[, fcount + i-].Value = reader.GetValue(i).ToString();
}
}

DataGridView控件添加数据时空白的可 错误情况的更多相关文章

  1. [置顶] DataGridView控件---绑定数据方法

             DataGridView控件是在windows应用程中显示数据最好的方式,它只需要几行简短的代码就可以把数据显示给用户,同时又支持增.删.改操作.今天将自己总结的增加数据的方法总结分 ...

  2. C# DataGridView控件清空数据完美解决方法

    C# DataGridView控件绑定数据后清空数据在清除DataGridview的数据时: 1.DataSource为NULL(DataGridView.DataSource= null;)这样会将 ...

  3. 转:C# DataGridView控件清空数据出错解决方法

    C# DataGridView控件绑定数据后清空数据在清除DataGridview的数据时: 1.DataSource为NULL(DataGridView.DataSource= null;)这样会将 ...

  4. DataGridVIew控件绑定数据之后的,增、插、删操作

    最开始没有绑定数据,很快就实现了增.插.删操作,可是绑定数据之后,进行这些操作就会报错. 网上对这方面的资料比较少,自己摸索着找到了解决方法,也就是直接对绑定的数据进行操作,这里以DataTable为 ...

  5. 将C#datagridview控件的数据导出到Excel中

    1.添加引用Microsoft.Office.Interop.Excel. 2.程序代码引用using Excel = Microsoft.Office.Interop.Excel; 3.控件事件代码 ...

  6. Xcode中给控件添加颜色时自动显示出颜色

    在iOS开发中,给一些控件设置颜色的时候,设置完不能立马看到颜色.必须要运行程序之后才能看到设置的颜色,如果颜色有偏差再回代码改参数,然后再运行看颜色很是麻烦.令人高兴得是Xcode有很多功能强大插件 ...

  7. 使用java(jdbc)向mysql中添加数据时出现“unknown column……”错误

    错误情况如题,出现这个错误的原因是这样的: 在数据库中,插入一个字符串数据的时候是需要用单引号引起来的. 而下面的代码,注意看: sta.executeUpdate("INSERT INTO ...

  8. C# DataGridView控件绑定数据后清空数据

    //1.this.dataGridView1.DataSource = null;//会将DataGridView的列也删掉 //2.this.dataGridView1.Columns.Clear( ...

  9. DataGridView控件绑定数据之后,置顶操作

    一个小小的置顶,就搞了半个小时,还是记录一下吧. 1.第一个问题就是datatable的插入只能是Insert DataRow,但是获取选中的行,都是DataGridViewRow,不能直接转换. 找 ...

随机推荐

  1. 【原创】Js:日期处理(日期格式必须【yyyy-mm-dd】才能转成long的毫秒!其他的不是【年-月-日】的格式,结果会是【NaN】)

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  2. iOS 定制controller过渡动画 ViewController Custom Transition使用体会

    最近学习了一下ios7比较重要的一项功能,就是 controller 的 custom transition. 在ios7中,navigation controller 中就使用了交互式过渡来返回上级 ...

  3. mybatis的insert简单使用

  4. Bootstrap分页插件:bootstrap-paginator

    今天和大家分享一个Bootstrap的分页插件:bootstrap-paginator. 插件地址: https://github.com/lyonlai/bootstrap-paginator 先看 ...

  5. HDU 4704 Sum (高精度+快速幂+费马小定理+二项式定理)

    Sum Time Limit:1000MS     Memory Limit:131072KB     64bit IO Format:%I64d & %I64u Submit Status  ...

  6. LESS学习笔记1

    个人理解:less是一个可以写函数的css

  7. 分类and分类延展

    1.Category简介 Category,又称为类别&类目&分类,是OC特有语法,在不修改原有类的基础上增加新的方法,一个庞大的类可以多人来分模块开发,有助于团队合作,或者对当前类方 ...

  8. 菜鸟学Linux命令:grep配合ls等使用

    linux grep命令 (global search regular expression(RE) and print out the line )是一种强大的文本搜索工具,它能使用正则表达式搜索文 ...

  9. hdu 1754 单点更新

    题意:很多学校流行一种比较的习惯.老师们很喜欢询问,从某某到某某当中,分数最高的是多少.这让很多学生很反感.不管你喜不喜欢,现在需要你做的是,就是按照老师的要求,写一个程序,模拟老师的询问.当然,老师 ...

  10. 网页制作技巧:iframe自适应高度

    转自:http://www.enet.com.cn/article/2012/0620/A20120620126237.shtml 通过Google搜索iframe 自适应高度,结果5W多条,搜索if ...