黑马程序员技术交流社区

标题: 数据库连接的几种常见问题 [打印本页]

作者: 贡宗新    时间: 2013-4-15 17:57
标题: 数据库连接的几种常见问题
本帖最后由 贡宗新 于 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, 下载次数: 8)

QQ截图20130415175347.jpg

作者: zerochen46    时间: 2013-4-15 18:06
DataSet可以存放多个表,而DataTable table = dataset.Tables[0];用来存取DataSet中的第一个表中的数据,DataRowCollection rows = table.Rows;就用来读取表中的行数据
作者: mustek    时间: 2013-4-15 20:01
从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;就用来读取表中的行数据。


作者: 熊薇    时间: 2013-4-15 22:10
1.对多值查询(cmd.ExecuteReader ())来说查询后的数据仍放在数据库中,这样的好处是当查询结果很
多时不占内存,但对于查询结果少的情况就很麻烦,C#提供了一种DataSet数据集,用于在内存中存放查询结果
2.对于为什么要用表格来存储获得的数据,这和数据库用表格来存储数据是一个道理的
3.从数据库中检索出来的数据是存放在DataSet数据集的Tables中,一般检索出来的只有一个表(故数据就放在
DataTable table=dataset.Tables[0]中,DataTable是表的类型);如果有多条数据,表自然就会有多行DataRowCollection rows = table.Rows 是获得表中所有行的集合
作者: 小人物    时间: 2013-4-16 22:52
首先楼主你对ExecuteScalar(); 方法的理解有点错误!该方法返回的首行首列的值,返回类型为object类型!用在使用聚合函数之类的查询语句中,比如select count(*)......而不是读取多行数据!另外datatable作用就是起到一个承载数据的作用,你想啊,从数据中查到数据后总要放在一个容器里,然后传到客服端啊!一般学了面向对象以后,都用类你作为承载数据的载体!根据数据库中的字段建立相应的类的属性!
作者: 风雪再现    时间: 2013-4-17 09:43
以前我也很疑惑,现在看了楼上的师兄的评论,好多了,谢谢师兄了
作者: 李奔    时间: 2013-4-18 09:25
恩,学习了!





欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2