http://www.sufeinet.com/plugin.php?id=keke_group

苏飞论坛

 找回密码
 马上注册

QQ登录

只需一步,快速开始

分布式系统框架(V2.0) 轻松承载百亿数据,千万流量!讨论专区 - 源码下载 - 官方教程

HttpHelper爬虫框架(V2.7-含.netcore) HttpHelper官方出品,爬虫框架讨论区 - 源码下载 - 在线测试和代码生成

HttpHelper爬虫类(V2.0) 开源的爬虫类,支持多种模式和属性 源码 - 代码生成器 - 讨论区 - 教程- 例子

查看: 2967|回复: 2

[C#语言基础] C#访问SQL Server数据库时若查询到数据库没有的数据vs2005报错

[复制链接]
发表于 2013-10-15 22:27:56 | 显示全部楼层 |阅读模式
  private void chaxu()
        {
            string myConStr = "Data Source=.;Initial Catalog=wo;Integrated Security=True";
            SqlConnection myCon = new SqlConnection(myConStr);
            myCon.Open();
            SqlCommand myCom = new SqlCommand();
            myCom.CommandType = CommandType.Text;
            string comStr = "select 成员编号,地址编号,姓氏,名字,角色,发送贺卡 from 家庭成员";
            comStr = comStr + " where 成员编号='" + textBox1.Text.ToString() + "'";
            myCom.CommandText = comStr;
            myCom.Connection = myCon;
            SqlDataReader myRead = myCom.ExecuteReader();
            myRead.Read();
           
                this.textBox1.Text = myRead.GetInt32(0).ToString();
                this.textBox2.Text = myRead.GetInt32(1).ToString();
                this.textBox3.Text = myRead.GetString(2);
                this.textBox4.Text = myRead.GetString(3);
                this.textBox5.Text = myRead.GetString(4);
                this.textBox6.Text = myRead.GetBoolean(5).ToString();
            
            myRead.Close();
            myCon.Close();
        }
上面查询函数




真心求个人教 本人学生QQ 2362910894求解决方法


1. 开通SVIP会员,免费下载本站所有源码,不限次数据,不限时间
2. 加官方QQ群,加官方微信群获取更多资源和帮助
3. 找站长苏飞做网站、商城、CRM、小程序、App、爬虫相关、项目外包等点这里
发表于 2013-10-16 08:06:09 | 显示全部楼层
if (reader.Read())

你做个判断就行了,如果没有数据你还这样写
[code=csharp]this.textBox1.Text = myRead.GetInt32(0).ToString();
                this.textBox2.Text = myRead.GetInt32(1).ToString();
                this.textBox3.Text = myRead.GetString(2);
                this.textBox4.Text = myRead.GetString(3);
                this.textBox5.Text = myRead.GetString(4);
                this.textBox6.Text = myRead.GetBoolean(5).ToString();[/code]
那肯定会出错,因为没有数据时myRead.GetInt32(1)这样的数据是不存在的。
改成这样
[code=csharp]if (reader.Read())
{
this.textBox1.Text = myRead.GetInt32(0).ToString();
                this.textBox2.Text = myRead.GetInt32(1).ToString();
                this.textBox3.Text = myRead.GetString(2);
                this.textBox4.Text = myRead.GetString(3);
                this.textBox5.Text = myRead.GetString(4);
                this.textBox6.Text = myRead.GetBoolean(5).ToString();
}else
{
  return "没有数据,这里你自己处理"
}
[/code]
发表于 2013-10-16 08:06:41 | 显示全部楼层
另外提示一下你的图片无法显示的
您需要登录后才可以回帖 登录 | 马上注册

本版积分规则

QQ|手机版|小黑屋|手机版|联系我们|关于我们|广告合作|苏飞论坛 ( 豫ICP备18043678号-2)

GMT+8, 2024-5-17 18:34

© 2014-2021

快速回复 返回顶部 返回列表