using System.Data.SqlClient;
...
SqlConnection conn = new SqlConnection(@"server=ws7\leosql;database=AdventureWorks;uid=sa;pwd=lixiang@");
try
{
    conn.Open();
    SqlCommand cmd = new SqlCommand("SELECT * FROM Person.Address", conn);
    SqlDataReader reader = cmd.ExecuteReader();
    while(reader.Read())
    Console.WriteLine(reader["AddressLine1"]);
}
catch(SqlException ex)
{
    Console.WriteLine(ex.Message);
}
finally
{
    conn.Close();
}

[1] ExecuteNonQuery 方法
用法:ExecuteNonQuery方法用来执行INSERT、UPDATE、DELETE和其他没有返回值得SQL命令,——比如CREATE DATABASE 和 CREATE TABLE 命令。当使用 INSERT、UPDATE、DELETE时,ExecuteNonQuery返回被命令影响的行数。对所有其他命令,返回-1。

using System.Data.SqlClient;
...
SqlConnection conn = new SqlConnection(@"server=ws7\leosql;database=AdventureWorks;uid=sa;pwd=lixiang@");
try
{
 conn.open();
 ==============================================================
 -- INSERT 命令
 SqlCommand cmd = new SqlCommand("INSERT INTO titles(title_id, title, type, pubdate) " + 
 "VALUES('JP101', 'Programming Microsoft .NET', 'bussiness', 'May 2002')", conn);
 ==============================================================
 -- UPDATE 命令
 -- SqlCommand cmd = new SqlCommand("UPDATE titles SET title_id= 'JP2002' " + 
 -- "WHERE title_id = 'JP1001'", conn);
 ==============================================================
 -- DALETE 命令
 -- SqlCommand cmd = new SqlCommand("DELETE FROM titles WHERE title_id = 'JP202'", conn);
 ==============================================================
 cmd.ExecuteNonQuery();
}
catch(SqlException ex)
{
 Console.WriteLine(ex.Message); 
}
finally
{
 conn.Close();
}

 
[2] ExecuteScalar 方法
用法1:ExecuteScalar 方法执行一个SQL命令返回结果集的第一列的第一行。它经常用来执行SQL的COUNT、AVG、MIN、MAX 和 SUM 函数,这些函数都是返回单行单列的结果集。
''注意:''ExecuteScalar 一般返回一个Object类型,因此必须把它转换为强类型。如果转换不正确,.NET框架就会引发 InvalidCastException异常。

using System.Data.SqlClient;
...
SqlConnection conn = new SqlConnection(@"server=ws7\leosql;database=AdventureWorks;uid=sa;pwd=lixiang@");
try
{
 conn.open();
 SqlCommand cmd = new SqlCommand("SELECT MAX(advance) FROM titles", conn);
 decimal amount = (decimal) cmd.ExecuteScalar();
 Console.WriteLine("ExecuteScalar returned {0:c}", amount);
}
catch(SqlException ex)
{
 Console.WriteLine(ex.Message); 
}
finally
{
 conn.Close();
}

用法2.1:ExecuteScalar 方法的另一个普遍的用法是从数据库中检索BLOB(二进制大对象)。下面的例子从Pubs数据库的Pub_Info表的Logo字段中检索图像,并把他封装到一个位图中。

MemoryStream stream = new MemoryStream();
SqlConnection conn = new SqlConnection("server=ws7\leosql;database=pubs;uid=sa;pwd=lixiang@");
try
{
 conn.open();
 SqlCommand cmd = new SqlCommand("SELECT logo FROM pub_info WHERE pub_id='0736'", conn);
 byte[] blob = (byte[]) cmd.ExecuteScalar();
 stream.Write(blob, 0, blob.Length);
 Bitmap bitmap = new Bitmap(stream);
 // TODO:使用位图
 bitmap.Dispose();
}
catch(SqlException ex)
{
 Console.WriteLine(ex.Message); 
}
finally
{
 stream.Close();
 conn.Close();
}

 
用法2.2:您也许对如何把BLOB写入数据库感兴趣,答案是在包装了INSERT命令(该命令中包含了类型为byte[]的输入参数)的命令对象上调用ExcuteNonQuery方法。下面例子在Pubs数据库的Pub_Info表中插入一条记录,记录的Logo字段包含一个BLOB。

-- 定义和初始化blob变量
FileStream stream = new FileStream("Logo.jpg", FileMode.Open);
byte[] blob = new byte[stream.Length];
stream.Read(blob, 0, (int) stream.Length);
stream.Close();

SqlConnection conn = new SqlConnection("server=ws7\leosql;database=pubs;uid=sa;pwd=lixiang@");
try
{
 conn.open();
 SqlCommand cmd = new SqlCommand("INSERT INTO pub_info(pub_id, logo) VALUES('9937', @logo)", conn);
 cmd.Parameters.Add("@logo", blob);
 cmd.ExecuteNonQuery();
}
catch(SqlException ex)
{
 Console.WriteLine(ex.Message); 
}
finally
{
 stream.Close();
 conn.Close();
}
 
[3] ExecuteReader 方法
用法:
ExecuteReader 方法存在的目的只有一个:尽可能快地对数据库进行查询并得到结果。ExecuteReader 返回一个DataReader对象:如果在SqlCommand对象中调用,则返回SqlDataReader;如果在OleDbCommand对象中调用,返回的是OleDbDataReader。可以调用DataReader的方法和属性迭代处理结果集。它是一个快速枚举数据库查询结果的机制,是只读、只进的。对SqlDataReader.Read的每次调用都会从结果集中返回一行。

using System.Data.SqlClient;
...
SqlConnection conn = new SqlConnection(@"server=ws7\leosql;database=AdventureWorks;uid=sa;pwd=lixiang@");
try
{
 conn.Open();
 SqlCommand cmd = new SqlCommand("SELECT * FROM titles", conn);
 SqlDataReader reader = cmd.ExecuteReader();
 while(reader.Read())
  Console.WriteLine(reader["title"]);
  =================================
  -- Console.WriteLine(reader.GetName(0));
  =================================
}
catch(SqlException ex)
{
 Console.WriteLine(ex.Message);
}
finally
{
 conn.Close();
}

 
DataReader还有一个GetValue方法可以用来检索字段的值。GetValue返回一个一般性的Object,但是被无数个返回强类型的Get方法补充,比如GetInt32和GetDecimal(参考MSDN2005)。对GetOrdinal的调用是必须的,因为GetDecimal只接受整型索引。GetOrdinal所做的工作正好与GetName相反——它把字段名转换成数字索引。
注意:DataReader必须处理Close方法。

using System.Data.SqlClient;
...
SqlConnection conn = new SqlConnection(@"server=ws7\leosql;database=AdventureWorks;uid=sa;pwd=lixiang@");
try
{
 conn.Open();
 SqlCommand cmd = new SqlCommand("SELECT * FROM titles WHERE advance != 0", conn);
 SqlDataReader reader = cmd.ExecuteReader();
 int index = reader.GetOrdinal("advance");
 while(reader.Read())
  Console.WriteLine("{0:c}", reader.GetDecimal(index));
  =================================
  -- Console.WriteLine(reader.GetName(0));
  =================================
 ''reader.Close();''
}
catch(SqlException ex)
{
 Console.WriteLine(ex.Message);
}
finally
{
 ========================================================
 -- 可以配置DataReader,使它真的可以关闭一个底层连接
 -- reader = cmd.ExecuteReader(CommandBehavior.CloseConnection);
 ========================================================
 conn.Close();
}

ExecuteNonQuery(),ExecuteScalar(),ExecuteReader的用法-转的更多相关文章

  1. ExecuteReader(),ExecuteNonQuery(),ExecuteScalar(),ExecuteXmlReader()之间的区别

    本文来自:http://www.cnblogs.com/zhouxiaxue/archive/2006/05/12/398266.html http://www.cnblogs.com/yaoxc/a ...

  2. ExecuteScalar,ExecuteReader,ExecuteNonQuery区别

    ExecuteScalar is typically used when your query returns a single value. If it returns more, then the ...

  3. ASP.NET中的ExecuteNonQuery()方法的用法

    下面我将详细讲解在机房收费系统D层中如何对数据库的增加.删除.修改,最后再来总结一下 ExecuteNonQuery(),ExecuteScalar(),ExecuteReader的用法: 一.增.删 ...

  4. ExecuteNonQuery()的用法

    ExecuteNonQuery()的用法 下面我们将详细讲解如何在Page_Load()中对数据库的增加.删除.修改,最后我们再来总结一下ExecuteNonQuery(),ExecuteScalar ...

  5. ASP.NET基础(一)

    ExecuteNonQuery()的用法 下面我们将详细讲解如何在Page_Load()中对数据库的增加.删除.修改,最后我们再来总结一下ExecuteNonQuery(),ExecuteScalar ...

  6. Asp.Net 初级 高级 学习笔记

    01.Main函数是什么?在程序中使用Main函数有什么需要注意的地方?02.CLR是什么?程序集是什么?当运行一个程序集的时候,CLR做了什么事情?03.值类型的默认值是什么?(情况一:字段或全局静 ...

  7. EntityFramework之Log(五)

    关于日志 属性日志 DbContext.Database.Log 属性被设置为一个委托,该委托能接受带有一个字符串参数的任何方法,最主要的是,通过设置它到 TextWriter 的 Write 方法将 ...

  8. 用于MySql的SqlHelper

    用于MySql的SqlHelper /// <summary> /// Title :MySqlHelper /// Author :WinterT /// Date :2015-1-8 ...

  9. ADO.NET学习(一)

    一.ADO.NET简介 ADO.NET可以看作是C#语言访问数据库的一种方式.编程语言编写的程序需要数据库的支持,那么怎样才能让他们建立连接呢?当然是ADO.NET 二.ADO.NET 整体流程 1) ...

随机推荐

  1. 英语发音规则---(e)s和-(e)d的读音规则

    英语发音规则---(e)s和-(e)d的读音规则 一.总结 一句话总结: 1.大部分可数名词的复数及动词第三人称单数的一般现在式,是以-(e)s结尾的? moths,glasses:digs,teac ...

  2. python基础-循环语句while

    循环语句:while\for\嵌套 循环控制语句:break\continue break:跳出整个循环,不会再继续循环下去 continue:跳出本次循环,继续下一次循环 while循环: coun ...

  3. Python基础-列表推导式

    python中列表推导式有三种数据类型可用:列表,字典,集合 列表推导式书写形式: [表达式 for 变量 in 列表]    或者  [表达式 for 变量 in 列表 if 条件] 1,列表推导式 ...

  4. Java_io_02_从一个目录拷贝文件到另一个目录下

    java从一个目录拷贝文件到另一个目录下   http://www.cnblogs.com/langtianya/p/4857524.html ** * 复制单个文件 * @param oldPath ...

  5. java String final + equal == 区别

    java String 是不可改变的类型. String a = "hello2"; String d = "hello"; final String b = ...

  6. Arc073_F Many Moves

    传送门 题目大意 有$n$个格子从左到右依次挨着,一开始有两枚棋子分布在$A,B$某一个或两个格子里,有$m$个操作,第$i$次操作要求你把其中一个棋子移到$X_i$上,移动一个棋子的代价是两个格子之 ...

  7. Gym - 100570B :ShortestPath Query(SPFA及其优化)

    题意:给定N点M边的有向图,每条边有距离和颜色,一条有效路径上不能有相邻的边颜色相同.现在给定起点S,多次讯问S到点X的最短有效距离. TLE思路:用二维状态dis(u,c)表示起点到u,最后一条边的 ...

  8. tomcat可以访问默认页面,但是无法访问webapp下的指定项目

     tomcat可以访问默认页面,但是无法访问webapp下的指定项目 1.注意下安装tomcat时的默认端口,8005,8009,8080,我这边没有修改,根据需要自行修改,确保tomcat可以启动 ...

  9. NOIp2018集训test-10-18 (bike day4)

    这是一套简单题,这几天的考试让bike老爷感觉很绝望,说实话我也确实不知道还能怎么更简单了. 这几天的题换做llj.sxy应该都能轻松AK吧,至少随便考个250+应该不是问题吧,我越来越觉得觉得我跟他 ...

  10. Android 开发:开源库Speex支持arm64的动态库文件

    随着处理器制造工艺的不断进步,和Android系统的不断发展,最近出了arm64-v8a的架构,由于项目中用到了speex的第三方语音编解码的动态库,其他架构的处理器暂不用说,一切正常,唯独到arm6 ...