A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 林言 注册黑马   /  2012-5-19 20:19  /  2043 人查看  /  5 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

sqlc.CommandText = "slect avg(Score) from T_Student 怎么获得那个平均数呢?

评分

参与人数 1技术分 +1 收起 理由
宋天琪 + 1

查看全部评分

5 个回复

倒序浏览
定义一个变量 接收 ExecuteScalar() 方法   返回的值  就是了----
回复 使用道具 举报
int avg = (int)cmd.ExecuteScalar();   我刚才 又 测试了下,这样就 更 详细了吧-----

评分

参与人数 1技术分 +1 收起 理由
宋天琪 + 1

查看全部评分

回复 使用道具 举报
其实,这个问题是涉及到SqlCommand命令的几种执行方式,
                    cmd.ExecuteNonQuery();
                    cmd.ExecuteReader();
                    cmd.ExecuteScalar();
                    cmd.ExecuteXmlReader();
等等,这里不详细介绍这几个方法,MSDN上都有,这几个方法都有返回值类型的提示,你根据返回值的类型定义一个变量,并将执行结果赋值给变量,就能操作返回值了。

例如你说的返回平均数,根据你的SQL语句判断你返回的是一个数值,进而考虑最优的是使用ExecuteScalar();官方解释是:返回结果集中第一行的第一列的值;如果结果集为空,则为空引
用,返回值的类型为object类型的数据。

评分

参与人数 1技术分 +1 收起 理由
郑文 + 1

查看全部评分

回复 使用道具 举报
//获取T_Student 学生成绩表的平均成绩
sqlc.CommandText = "slect avg(Score) from T_Student ";
//定义一个变量,采用SqlCommand命令的cmd.ExecuteScalar();
float avg = (float)cmd.ExecuteScalar();
回复 使用道具 举报
聚集函数avg()就是用来求平均数的,然后根据程序中具体的需要,定义一个变量来接收这个返回值,定义变量时选择好类型就ok了
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马