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

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 贡宗新 中级黑马   /  2013-4-15 17:57  /  2050 人查看  /  6 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

本帖最后由 贡宗新 于 2013-4-17 15:51 编辑

连接数据库的时候常用的是创建连接new一个sqlconnection对象,然后open,然后sqlcommand创建命令最后一步根据查询结果来显示
有三种
第一种: cmd.ExecuteNonQuery();  执行返回数据库中影响的行数
第二种:cmd.ExecuteScalar(); 读取一行一列的数据 读取多行数据
第三种:cmd.ExecuteReader 查询结果放在服务器  DataSet查询结果放在客户端

   DataTable table = dataset.Tables[0];
                    DataRowCollection rows = table.Rows;
datatable用来干嘛的,为什么要用表格来存储获得的数据,搞不懂箭头指向的那几部的原因,知道的人讲解一下

QQ截图20130415175347.jpg (60.76 KB, 下载次数: 11)

QQ截图20130415175347.jpg

评分

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

查看全部评分

6 个回复

倒序浏览
DataSet可以存放多个表,而DataTable table = dataset.Tables[0];用来存取DataSet中的第一个表中的数据,DataRowCollection rows = table.Rows;就用来读取表中的行数据

评分

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

查看全部评分

回复 使用道具 举报
从DataSet中读出DataTable
DataTable=DataSet.Tables[0]或DataSet.Tables["表名"]  
DataTable table=ds[i]或DataTable table=ds["学生表"]
i为DataSet中的索引值,因为DataSet可存放多个DataTable,可以根据索引值来找DataTable或直接写DataTable的名称来找DataTable
datarowcollection rows=table.rows;就用来读取表中的行数据。

评分

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

查看全部评分

回复 使用道具 举报
1.对多值查询(cmd.ExecuteReader ())来说查询后的数据仍放在数据库中,这样的好处是当查询结果很
多时不占内存,但对于查询结果少的情况就很麻烦,C#提供了一种DataSet数据集,用于在内存中存放查询结果
2.对于为什么要用表格来存储获得的数据,这和数据库用表格来存储数据是一个道理的
3.从数据库中检索出来的数据是存放在DataSet数据集的Tables中,一般检索出来的只有一个表(故数据就放在
DataTable table=dataset.Tables[0]中,DataTable是表的类型);如果有多条数据,表自然就会有多行DataRowCollection rows = table.Rows 是获得表中所有行的集合

评分

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

查看全部评分

回复 使用道具 举报
首先楼主你对ExecuteScalar(); 方法的理解有点错误!该方法返回的首行首列的值,返回类型为object类型!用在使用聚合函数之类的查询语句中,比如select count(*)......而不是读取多行数据!另外datatable作用就是起到一个承载数据的作用,你想啊,从数据中查到数据后总要放在一个容器里,然后传到客服端啊!一般学了面向对象以后,都用类你作为承载数据的载体!根据数据库中的字段建立相应的类的属性!
回复 使用道具 举报
以前我也很疑惑,现在看了楼上的师兄的评论,好多了,谢谢师兄了
回复 使用道具 举报
李奔 中级黑马 2013-4-18 09:25:42
7#
恩,学习了!
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马