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. 关于Eclipse的工作空间设置默认个数和配置

    &

  2. sharepoint 中用自带的download.aspx实现文件的下载,中文文件名编码的问题

    ]中的路径绑定的是下载路径,用到了sharepoint中自带的download.aspx下载页面,只要将文件的URL赋值给sourceurl即可,但是我前台用的是<a>标签的href来导向 ...

  3. 如何通过PhpMyAdmin批量删除MYSQL数据库数据表

    使用这个方法前,强烈建议先备份整个数据库.至于怎么备份?你不会么?在本文下方留言吧. 具体方法:复制下面的php执行语句,保存为sql.php文件(注意配置数据库名称.密码.数据表头),通过ftp上传 ...

  4. Linux 命令 - df: 报告磁盘空间的占用情况

    df 命令列出指定的文件名所在的文件系统上可用磁盘空间的数量. 如果没有指定文件名,则显示当前所有使用中的文件系统.默认情况下,磁盘空间以 1K 为一块显示,如果设置了环境变量 POSIXLY_COR ...

  5. HDOJ2016数据的交换输出

    数据的交换输出 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Sub ...

  6. 【poj4011】Automated Telephone Exchange

    题目:Automated Telephone Exchange poj URL:http://poj.org/problem?id=4011 原题如下图: 题意: 就是一个三位数减去两个小于或等于99 ...

  7. 第六十六篇、OC_Sqlite数据库操作

    #import <Foundation/Foundation.h> #import <sqlite3.h> #define kFilename @"data.sqli ...

  8. 119. Pascal's Triangle II

    Given an index k, return the kth row of the Pascal's triangle. For example, given k = 3,Return [1,3, ...

  9. javascript-对象的创建(一)

    <!DOCTYPE html> <%@ page language="java" contentType="text/html; charset=UTF ...

  10. JAVA_SE复习(OOP2)

    面向对象编程(二) 一.static 关键字 静态属性 1.不能覆盖静态方法.要被覆盖的方法必须是非静态的.在继承链中具有相同方法名的两个静态方法是两个互相独立的类方法.调用子类的静态方法只是将父类的 ...