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. [改善Java代码]多线程使用Vector或HashTable

    Vector是ArrayList的多线程版本,HashTable是HashMap的多线程版本,这些概念我 们都很清楚,也被前辈嘱咐过很多次,但我们经常会逃避使用Vector和HashTable,因为用 ...

  2. PS基础学习 2---图层蒙版

    1,蒙版,字面意思上的理解就是:把底层图片上面加上一层图层蒙着,通过画笔工具控制底层图片和上面一层图层的显示效果.常用于图层的无缝隙合成. 我们可以先看一下下面的这个小例子,这个就是蒙版的一个小应用: ...

  3. Java Concurrency - Semaphore 信号量

    Semaphore 是一个控制访问多个共享资源的计数器. 当一个线程想要访问某个共享资源,首先,它必须获得 semaphore.如果 semaphore 的内部计数器的值大于 0,那么 semapho ...

  4. Java Concurrency - Concurrent Collections

    Data structures are a basic element in programming. Almost every program uses one or more types of d ...

  5. secureFX中出现中文乱码修改方法

    1. 找到SecureFX配置文件夹(选项--全局选项,常规下的配置文件夹),比如:D:\Program files\SecureCRT\DATA:2. 在配置文件夹下的Sessions子目录中,找到 ...

  6. WM_NCCALCSIZE消息处理详解

    [前言]指定应用程序的标题高度和边框的宽度的方法有很多种.其中最普遍的方法有下面的两种:第一种:创建没有标题栏应用程序,在客户区让出一部分空间用一幅图片画一个标题栏,让人“误认为”是标题栏.第二种:处 ...

  7. Android报错:The content of the adapter has changed...与Channel is unrecoverably broken and will be disposed的分析与解决办法

    在Android中adapter错误: The content of the adapter has changed but ListView did not receive a notificati ...

  8. 会话—cookie

    什么是会话?       会话可简单理解为:用户开一个浏览器,点击多个超链接,访问服务器多个web资源,然后关闭浏览器,整个过程称之为一个会话. 会话过程中要解决的一些问题?       每个用户在使 ...

  9. MSSQL AlwaysOn中的“主角色中的连接”和“可读辅助副本”初探

    一.开篇 在进行配置只读路由的时候,需要进行配置可用性组中的可用性副本,如下如所示: 每一项都是啥意思可以看看这个链接 https://msdn.microsoft.com/zh-cn/library ...

  10. CSS 初体验之一

    层叠样式表 (Cascading Style Sheets)”,它主要是用于定义HTML内容在浏览器内的显示样式. 1.首先先看盒装模型,如下图,平时设置的width,height是指元素内容(con ...