using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Data.SqlClient;
using System.Configuration;
using System.Data;
 
/// <summary>
///SqlHelper 的摘要说明
/// </summary>
public class SqlHelper
{
    static string connStr = ConfigurationManager.ConnectionStrings["JSDB"].ConnectionString;
public SqlHelper()
{
}
    
 
    public static int ExecuteNonquery(string cmdText,params SqlParameter[] ps)
    {
        using (SqlConnection conn = new SqlConnection(connStr))
        {
            using (SqlCommand cmd = new SqlCommand())
            {
                conn.Open();
                cmd.Connection = conn;
                cmd.CommandText = cmdText;
                cmd.Parameters.AddRange(ps);
             return    cmd.ExecuteNonQuery();
            }
        }
    }
 
 
    public static object  ExecuteScalar(string cmdText, params SqlParameter[] ps)
    {
        using (SqlConnection conn = new SqlConnection(connStr))
        {
            using (SqlCommand cmd = new SqlCommand())
            {
                conn.Open();
                cmd.Connection = conn;
                cmd.CommandText = cmdText;
                cmd.Parameters.AddRange(ps);
                return cmd.ExecuteScalar();
            }
        }
    }
 
    public static DataSet GetDsByAdapter(string cmdText, params SqlParameter[] ps)
    {
        DataSet ds = new DataSet(); 
 
        using (SqlConnection conn = new SqlConnection(connStr))
        {
            using (SqlCommand cmd = new SqlCommand())
            {
                conn.Open();
                cmd.Connection = conn;
                cmd.CommandText = cmdText;
                cmd.Parameters.AddRange(ps);
                using (SqlDataAdapter apt = new SqlDataAdapter(cmd))
                {
                    apt.Fill(ds);
                }
            }
        }
        return ds;
    }
 
 
    public static SqlDataReader GetReader(string cmdText, params SqlParameter[] ps)
    {
        //using (SqlConnection conn = new SqlConnection(connStr))
        //{
        //    using (SqlCommand cmd = new SqlCommand())
        //    {  conn.Open();
        //        cmd.Connection = conn;
        //        cmd.CommandText = cmdText;
        //        cmd.Parameters.AddRange(ps);
 
        //       return  cmd.ExecuteReader(CommandBehavior.CloseConnection);
        //    }
        //}
 
        SqlConnection conn = new SqlConnection(connStr);
        SqlCommand cmd = new SqlCommand();
        conn.Open(); cmd.Connection = conn; cmd.CommandText = cmdText; cmd.Parameters.AddRange(ps);
        return cmd.ExecuteReader(CommandBehavior.CloseConnection);
 
    }
 
 
}
==============调用

  /*
                string sql = "insert into mytest (id,name) values(1,'abc')";
                SqlHelper.ExecuteNonquery(sql);
         */
 
        /*
              string sql = "select * from mytest";
              object obj =  SqlHelper.ExecuteScalar(sql);
         */
 
        /*
          string sql = "select * from mytest";
        DataSet obj = SqlHelper.GetDsByAdapter(sql);
         */
 
        string sql = "select * from mytest";
        SqlDataReader reader = SqlHelper.GetReader(sql);
        Dictionary<string, string> dic = new Dictionary<string, string>();
        while (reader.Read())
        {
            dic.Add(reader["Id"].ToString(),reader["Name"].ToString());

}

ExecuteNonquery  用于 非查询操作,用于查询的操作,没有结果;如果sql中有查询的语句有非查询的语句,此操作返回所有insert update delete这些操作的影响行数;

ExecuteScalar 返回首行手列内容;不是说就不能执行 insert等操作,没问题,但是得不到反应的结果,数据能插入数据库没问题;多个操作,返回第一个有结果集操作的首行收列(比如 insert ...output或者select等)

Adapter和reader返回 查询的结果,不是说不能执行 非查询操作,没问题数据照样执行,但是得不到任何反应;

  public  class Comunicate
    {
   static   string  connStr = ConfigurationManager.AppSettings["connStr"].ToString();
      
      public static void ExecuteNonquery()
      {
          //execurenonquery update delete insert 返回受这3中操作的影响的行数,【通过输出参数output可以输出一些内容】
 
 
 
        //  string sql = "insert into person (name ,age) values ('张三',25)";//插入一条数据,返回受影响行数1
         // string sql = "select * from person";//-1
         // string sql = "select * from person where name = 'shit'";//-1
          using (SqlConnection conn = new SqlConnection(connStr))
          {
              using (SqlCommand cmd = new SqlCommand())
              {
                 // string sql = "InsertOutAge";//得到的还是受影响的行数1,没有得到age
                  //string sql = "InsertOutAgeTwo";
                  //string sql = "InserTsELECT";
                  string sql = "InserTsELECT3";//添加1行删除1行 ,影响结果是2
                  conn.Open();
                  cmd.Connection = conn;
                  cmd.CommandText = sql;
 
                  //存储过程的
                  //cmd.CommandType = CommandType.StoredProcedure;
                  //cmd.Parameters.Add("@name","李四");
                  //SqlParameter p = new SqlParameter();
                  //p.Direction = ParameterDirection.Output;
                  //p.ParameterName = "@age";
                  //p.SqlDbType = SqlDbType.Int;
                  //p.Size = 4;
                 
                  //cmd.Parameters.Add(p);
 
                  int result = cmd.ExecuteNonQuery();//影响行数1
                 // object re = p.Value;//输出参数 92
              }
          }
      
      }
 
      public static void ExeceteScalar()
      {
          using (SqlConnection conn = new SqlConnection(connStr))
          {
              using (SqlCommand cmd = new SqlCommand())
              {
 
                  //string sql = "select * from person";//返回首航受列内容
                  string sql = "insert into person(age) values(30);select * from person;select * from person where id>6";//多个操作返回多张表时,一第一个为准,返回首行首列内容
                  cmd.Connection = conn;
                  conn.Open();
                  cmd.CommandText = sql;
                object resltu =  cmd.ExecuteScalar();
              }
          }
      
      }
 
      public static void GetDataTable()
      {
//可以执行insert操作,但是此方法只是用来得到 select的内容 
         // string sql = "insert into person (name,age) values ('阿杜',25);select * from person";//执行了insert 把select的fill到datatable
          string sql = "insert into person (name,age) values ('阿杜',26)";//能狗插入数据成功
          using (SqlDataAdapter apt = new SqlDataAdapter(sql,connStr))
          {
              DataTable dt = new DataTable();
              
              apt.Fill(dt);
 
          }
      }

回顾Ado.Net的更多相关文章

  1. Oracle 应用于.NET平台

    1. 回顾ADO.NET ADO.NET是一组用于和数据源进行交互的面向对象类库集,它存在于.Net Framework中.通常情况下,数据源可以是各种类型的数据库,利用ADO.NET可以访问目前几乎 ...

  2. .NET基础操作回顾_使用ADO.NET操作SqlServer使用的类

    有些工具用的久了或者有新工具出现后,就慢慢的遗忘了很多,它们从熟悉的变成陌生,当然,对于我们来说不是好事吧. 今天回顾一下ADO.NET用到的MS的基础类库,先上代码(标准的SqlServer操作) ...

  3. ADO.NET基础巩固-----连接类和非连接类

          最近的一段时间自己的状态还是不错的,早上,跑步,上自习看书,下午宿舍里面编程实战,晚上要么练习代码,要么去打球(在不打就没机会了),生活还是挺丰富的. 关于C#的基础回顾就先到前面哪里,这 ...

  4. ADO与ADO.NET的区别与介绍

    1. ADO与ADO.NET简介ADO与ADO.NET既有相似也有区别,他们都能够编写对数据库服务器中的数据进行访问和操作的应用程序,并且易于使用.高速度.低内存支出和占用磁盘空间较少,支持用于建立基 ...

  5. ADO和ADO.NET的区别

    1. ADO与ADO.NET简介 ADO与ADO.NET既有相似也有区别,他们都能够编写对数据库服务器中的数据进行访问和操作的应用程序,并且易于使用.高速度.低内存支出和占用磁盘空间较少,支持用于建立 ...

  6. ADO.NET之使用DataGridView控件显示从服务器上获取的数据

    今天回顾下ADO.NET中关于使用DataGridiew控件显示数据的相关知识 理论整理: 使用 DataGridView 控件,可以显示和编辑来自多种不同类型的数据源的表格数据. SqlDataAd ...

  7. ADO.NET知识的运用一(Day 26)

    哈哈,又到了总结的时间了,来回顾一下今天主要学了关于ADO.NET的哪些知识吧.(这次学的ADO访问数据库主要以访问SQL数据库为主) 理论:  首先我们要知道为什么要学习ADO.NET? 因为我们之 ...

  8. [转]一个普通IT人的十年回顾---金旭亮

    金旭亮老师十年体会,很有收获.转自网络. 金旭亮于1989年与超级解霸的开发者梁肇新同时迈入广西大学的校门,却走了一条与其不同的路. 1994年起开始自学计算机专业本科课程,并开始编程,从未间断,迄今 ...

  9. 金老师的经典著作《一个普通IT人的十年回顾》

    学习人生             -------一个普通IT人的十年回顾(上)序从1994到2003,不知不觉之间,我已在计算机技术的世界里沉浸了十年.有位哲人说过:如果一个人能用十年的时间专心致志地 ...

随机推荐

  1. mysql 5.7 root password 过期

    重新修改root密码 SET PASSWORD FOR 'root'@'localhost' = PASSWORD('newpass'); ALTER USER 'root'@localhost' P ...

  2. Delphi7使用ADO直接连接Excel读取数据

    我之前是连接成功的,现在不知道为什么怎样连都失败.最后才知道是Office版本的问题,office2007已经是基于xml的.和以前的不一样. Excel2003的连接字符串: 'Provider=M ...

  3. mysql中文乱码的一点理解

    我们自己鼓捣mysql时,总免不了会遇到这个问题:插入中文字符出现乱码,虽然这是运维先给配好的环境,但是在自己机子上玩的时候咧,总得知道个一二吧,不然以后如何优雅的吹牛B. 如果你也遇到了这个问题,咱 ...

  4. JMS - 基本概念

    连接工厂创建连接对象的工厂. 连接客户端与 JMS 服务器之间建立的连接.创建一个或多个会话. 会话创建消息.生产者和消费者,会话是 消息由三部分组成:消息头.消息属性和消息体. 生产者创建和发送消息 ...

  5. Nginx - HTTP Configuration, the Location Block

    Nginx offers you the possibility to fine-tune your configuration down to three levels — at the proto ...

  6. 解决MS Office下载网站数据失败的问题

    最近遇到在MS Excel中建立的Web Query在创建完成后过了一段时间(或关闭文件后再次打开文件并刷新数据)出现无法刷新的问题,点击刷新时报错如下: 无法下载您要求的信息. 这是一个很不友好的报 ...

  7. Sqlserver中关于锁

    大多数数据库需要同时处理多个查询,这些查询并不会像车等待红绿灯排队等待,而是会寻找最短的路径执行,因此需要一个红绿灯进行约束,这个红绿灯就是锁 理论上所有的事务之间应该是完全隔离的,但是事实上隔离的成 ...

  8. sqlserver2008 如何定时清理索引碎片

    sqlserver2008 如何定时清理索引碎片 查询索引引起的表垃圾碎片sql脚本:  SELECT object_name(a.object_id) [TableName] ,a.index_id ...

  9. 编译android5.0源码的

    java环境 Android 5.1 用到的jdk不再是Oracle 的 jdk ,而是开源的 openjdk,在ubuntu安装好后,使用如下命令安装jdk: $sudo apt-get insta ...

  10. C#学习笔记之线程 - 通知Signal

    通知事件等待句柄 Signal With EventWaitHandle 事件等待句柄常用于通知.当一个线程等待直到接收到另外一个线程发出的信号.事件等待句柄是最简单的信号结构,它与C#事件无关.有三 ...