写一个小程序,将数据库中的两张表相关信息显示在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. 14.约瑟夫环问题[JosephusProblem]

    [题目] n个数字(0,1,…,n-1)形成一个圆圈,从数字0开始,每次从这个圆圈中删除第m个数字(第一个为当前数字本身,第二个为当前数字的下一个数字).当一个数字删除后,从被删除数字的下一个继续删除 ...

  2. iOS 和 Android 中的后台运行问题

    后台机制的不同,算是iOS 和 Android的一大区别了,最近发布的iOS7又对后台处理做了一定的更改,找时间总结一下编码上的区别,先做个记录. 先看看iOS的把,首先需要仔细阅读一下Apple的官 ...

  3. HDU 5651 xiaoxin juju needs help (组合数)

    xiaoxin juju needs helpTime Limit: 1000MS Memory Limit: 65536KB 64bit IO Format: %I64d & %I64uSu ...

  4. UEditor插入表格没有边框但有间距

    百度编辑器ueditor插入一个表格后,在编辑过程中有表格,但是保存后,在前台网页中没有边框,但有间距,设置方法如下: 在UEditor文件夹下打开ueditor.all.js文件,找到UE.comm ...

  5. JPush开发

    主要功能 保持与服务器的长连接,以便消息能够即时推送到达客户端 接收通知与自定义消息,并向开发者App 传递相关信息 SDK集成步骤 1.导入 SDK 开发包到你自己的应用程序项目 解压缩 jpush ...

  6. 菜鸟学Linux命令:chmod命令和数字文件权限

    chmod是一条在Unix系统中用于控制用户对文件的权限的命令(change mode单词前缀的组合)和函数.只有文件所有者和超级用户可以修改文件或目录的权限.可以使用绝对模式,符号模式指定文件的权限 ...

  7. mysql忘记密码修改方法

    1.干掉mysqld进程 kill -TERM mysqld 2.使用下面命令启动mysqld /usr/bin/mysqld_safe --skip-grant-tables & 3.新开一 ...

  8. hrbustoj 1429:凸多边形(计算几何,判断点是否在多边形内,二分法)

    凸多边形 Time Limit: 2000 MS    Memory Limit: 65536 K Total Submit: 130(24 users)   Total Accepted: 40(1 ...

  9. Java Hour8

    有句名言,叫做10000小时成为某一个领域的专家.姑且不辩论这句话是否正确,让我们到达10000小时的时候再回头来看吧. 本文作者Java 现经验约为7 Hour,请各位不吝赐教. Hour8 Jav ...

  10. 富士通F-02D 1630万像素翻盖手机docomo官方解锁送充电器

    此款富士通F-02D手机是非常漂亮的一款拿在手上十分有质感的日版翻盖手机.2011年11月上市的新款手机.1630万像素的高清摄像头,防水,带指纹锁,高清HDMI输出,非常漂亮的手机灯光设计,其性能配 ...