java executenonquery_ExecuteNonQuery,ExecuteReader,ExecuteScalar 区别

ExecuteNonQuery方法 :执行非查询SQL操作,包括增insert、删delete、改update

ExcuteReader方法 :执行查询,返回DataReader,通过DataReader的对象dr["列名"]

可以取得数据,一次读一行,可以通过while(dr.Read())进行循环读取

ExecuteScalar方法 :执行查询,只返回一个数据

在连接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();

类别:sql知识 查看评论

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值