[转]ExecuteNonQuery()、ExecuteReader()、ExecuteScalar()的简单说明
2010-10-21 22:46
357 查看
http://blog.csdn.net/wuyujie1219/archive/2009/07/26/4380956.aspx
在连接SQL Server数据库:首先创建SqlConnection类和SqlCommand类实例分别用于连接到SQL Server数据库和执行SQL语句命令,然后打开数据连接并使用SqlCommand的相应方法执行SQL语句。
ExecuteNonQuery()方法执行SQL语句并且不返回数据;
ExecuteReader()方法将SQL语句发送给SqlConnection并生产一个SqlDataReader类对象,该SqlDataReader对象包含SQL命令返回的数据;
ExecuteScalar()方法执行SQl查询,并返回查询结果集中的第一行的第一列,忽略额外的列或行!
例如:
SqlConnection MyConncetion = new SqlConnection(m_SqlConnection);
SqlCommand MyCmd = new SqlCommand(p_StrSql, MyConncetion);
一:
MyConncetion.Open();
MyCmd.ExecuteNonQuery();
二:
MyConncetion.Open();
SqlDataReader MyReader = MyCmd.ExecuteReader();
if (MyReader.Read())
{
return 0;
}
else
{
throw new Exception("Value Unavailable!");
}
三:
MyConnection.Open();
SqlDataAdapter SqlDa = new SqlDataAdapter(p_StrSql, MyConnection);
DataSet Ds = new DataSet("ds");
SqlDa.Fill(Ds);
四:
MyConncetion.Open();
object r = MyCmd.ExecuteScalar();
if (object.Equals(r, null))
{
throw new Exception("Value Unavailable!");
}
else
{
return (int)r;
}
注意:ExecuteReader() 方法需要配合 SqlDataReader 对象使用,执行得到的数据集为只读且光标只能从前向后移动。
在连接SQL Server数据库:首先创建SqlConnection类和SqlCommand类实例分别用于连接到SQL Server数据库和执行SQL语句命令,然后打开数据连接并使用SqlCommand的相应方法执行SQL语句。
ExecuteNonQuery()方法执行SQL语句并且不返回数据;
ExecuteReader()方法将SQL语句发送给SqlConnection并生产一个SqlDataReader类对象,该SqlDataReader对象包含SQL命令返回的数据;
ExecuteScalar()方法执行SQl查询,并返回查询结果集中的第一行的第一列,忽略额外的列或行!
例如:
SqlConnection MyConncetion = new SqlConnection(m_SqlConnection);
SqlCommand MyCmd = new SqlCommand(p_StrSql, MyConncetion);
一:
MyConncetion.Open();
MyCmd.ExecuteNonQuery();
二:
MyConncetion.Open();
SqlDataReader MyReader = MyCmd.ExecuteReader();
if (MyReader.Read())
{
return 0;
}
else
{
throw new Exception("Value Unavailable!");
}
三:
MyConnection.Open();
SqlDataAdapter SqlDa = new SqlDataAdapter(p_StrSql, MyConnection);
DataSet Ds = new DataSet("ds");
SqlDa.Fill(Ds);
四:
MyConncetion.Open();
object r = MyCmd.ExecuteScalar();
if (object.Equals(r, null))
{
throw new Exception("Value Unavailable!");
}
else
{
return (int)r;
}
注意:ExecuteReader() 方法需要配合 SqlDataReader 对象使用,执行得到的数据集为只读且光标只能从前向后移动。
string oSql = "select id, password, name, level from verify"; SqlCommand comm = new SqlCommand(oSql, con); con.Open();//在调用方法前打开数据库连接,可以减少数据库连接所花的时间,节省数据库资源。 SqlDataReader dr = comm.ExecuteReader (); While(dr.Read()) { String id = ""; id = dr[0].ToString(); //(0为第一列) //或 id=dr["id"].ToString();(引用字段名) //或id= dr.GetString (dr.GetOrdinal ("id")); } //在读取数据结束后才能关闭数据库,因为 SqlDataReader 对象的数据源必须保持数据库连接。 con.Close();
相关文章推荐
- ExecuteNonQuery();ExecuteReader();ExecuteScalar();的简单用法
- ExecuteNonQuery();ExecuteReader();ExecuteScalar();的简单用法
- ExecuteNonQuery();ExecuteReader();ExecuteScalar();的简单用法
- ExecuteNonQuery();ExecuteReader();ExecuteScalar();的简单用法
- ExecuteNonQuery();ExecuteReader();ExecuteScalar();的简单用法
- ExecuteReader()、ExecuteNonQuery()和ExecuteScalar()有什么区别?
- ExecuteReader、ExecuteScalar、ExecuteNonQuery、ExecuteXmlReader的区别
- sql 查询语法汇总(二)ExecuteReader、ExecuteNonQuery、ExecuteScalar、SqlDataReader、SqlDataAdapter
- ExecuteNonQuery,ExecuteReader,ExecuteScalar
- 关于Command的ExecuteNonQuery(),ExecuteScalar(),ExecuteReader方法的区别
- 下面我们将详细讲解如何在Page_Load()中对数据库的增加、删除、修改,最后我们再来总结一下ExecuteNonQuery(),ExecuteScalar(),ExecuteReader的用法
- [.NET] - ExecuteNonQuery(),ExecuteReader(),ExecuteScalar(),ExecuteXmlReader()介绍
- ExecuteReader(),ExecuteNonQuery(),ExecuteScalar
- ExecuteNonQuery,ExecuteScalar,ExecuteReader,ExecuteXmlReader,ExecuteOracleNonQuery,ExecuteOracleScal
- ExecuteReader(),ExecuteNonQuery(),ExecuteScalar(),ExecuteXmlReader()之间的区别
- Sql_server四种执行ExecuteReader、ExecuteNonQuery、ExecuteScalar、DataSet.docx
- ExecuteNonQuery,ExecuteScalar,ExecuteReader的比较
- ExecuteReader(),ExecuteNonQuery(),ExecuteScalar(),ExecuteXmlReader()之间的区别
- ExecuteNonQuery、ExecuteScalar、Dataset、ExecuteReader的不同意义和用法
- C#中ExecuteReader、ExecuteNonQuery、ExecuteScalar、SqlDataReader、SqlDataAdapter和DataTable的使用