ADO--SqlCommand的一些方法

来源:互联网 发布:淘宝怎么买烟怎么搜 编辑:程序博客网 时间:2024/06/15 07:36
ExecuteScalar
SqlCommand的ExecuteScalar方法用于执行查询,并返回查询所返回的结果集中第一行的第一列,因为不能确定返回值的类型,所以返回值是object类型
ExecuteScalar()方法内部也是调用ExecuteReader()实现的。
SqlDataReader使用注意事项
数据库服务器缓存
当使用DataReader的时候必须保证Connection为Open状态
reader只读(不能通过reader修改数据。)、只进
reader每次读取一条就释放一条所以只能向前不能后退
由于功能有限,所以读取速度很快,适合从数据库中读取大量数据
使用reader根据列索引读取列数据而不是列名
使用强类型的GetString()、GetInt32、GetFloat()、GetDouble()….
数据库中的类型与C#的不太一样,数据库中的float,得用c#的GetDouble()来获取。
IsDbNull()
如果返回多个结果集则用NextResult()方法。通过do-while循环测试。
 
执行有多行结果集的用ExecuteReader
HasRow属性返回是否有行
SqlDataReader reader = cmd.ExecuteReader();...
while (reader.Read())
{     
 Console.WriteLine(reader.GetString(1));
}
reader的GetString、GetInt32等方法只接受整数参数,也就是序号,用GetOrdinal方法根据列名动态得到序号
更简单的方法reader[‘uUserName’]
为什么用using。Close:关闭以后还能打开。Dispose:直接销毁,不能再次使用。using在出了作用域以后调用Dispose,SqlConnection、 SqlDataReader等的Dispose内部都会做这样的判断:判断有没有close,如果没有Close就先Close再Dispose。
DataReader 必须独享一个Connection (除非设置了允许MARS,多活动结果集,在连接字符串中)
 
 
 
原创粉丝点击