public static  class SQLHelper
{
    //获取连接字符串,,首先添加对configuration的引用
    private static string connStr = ConfigurationManager.ConnectionStrings["dbConnStr"].ConnectionString;
    //ExecuteNonQuery方法----非查询的方法
    public static int ExecuteNonQuery(string sql,params SqlParameter[] parameters)
    {
        //1、创建连接对象
        using (SqlConnection conn=new SqlConnection(connStr))
        {
        //2、创建执行对象
            using (SqlCommand cmd=new SqlCommand(sql,conn))
            {
        //3、判断添加占位符集合
                if (parameters!=null)
                {
         cmd.Parameters.AddRange(parameters);
                }
        //4、执行操作前一步   打开连接
                conn.Open();
                //5、执行相应的操作
                return cmd.ExecuteNonQuery();
            }
        }
    }
    //ExecuteScalar方法-----返回查询结果的第一行第一列
    public static object ExecuteScalar(string sql,params SqlParameter[] parameters)
    {
        //1、创建连接对象
        using(SqlConnection conn=new SqlConnection(connStr))
        {
        //2、创建执行对象
            using(SqlCommand cmd=new SqlCommand(sql,conn))
            {
        //3、判断并添加占位符集合
                if(parameters!=null)
                {
                    cmd.Parameters.AddRange(parameters);
                }
        //4、执行语句前一部打开链接
                conn.Open();
        //5、执行相应操作
                return cmd.ExecuteScalar();
            }
        }
    }
//返回DataTable的方法
        public static DataTable ExecuteDataTable(string sql,params SqlParameter[] parameters)
        {
            DataTable table=new DataTable();
            //直接交给sqldataadapter执行
            using (SqlDataAdapter adapter=new SqlDataAdapter(sql,connStr))
            {
                //判断并添加占位符集合(利用存储过程),,返回结果
                if(parameters!=null)
                {
                    adapter.SelectCommand.Parameters.AddRange(parameters);
                }
                //将结果填充到table
                adapter.Fill(table);
            }
            return table;
        }

    public static SqlDataReader ExecuteReader(string sql,params SqlParameter[] parameters)
    {
        //因为每次都执行返回一行,不用using,,,创建连接
        SqlConnection  conn=new SqlConnection(connStr);
        //创建执行对象
        using(SqlCommand cmd=new SqlCommand(sql,conn))
        {
            if(parameters!=null)
            {
                cmd.Parameters.AddRange(parameters);
            }
            try
            {
                //判断连接对象是否是连接状态,不是就打开
                if(conn.State==ConnectionState.Closed)
                {
                    conn.Open();
                }
                //在连接打开的前提下执行读取命令,,随着conn的关闭而关闭
               return cmd.ExecuteReader(CommandBehavior.CloseConnection);
            }
                //没有可读数据的时候关闭连接变释放资源
            catch
            {
                conn.Close();
                conn.Dispose();
                throw;
            }
        }
    }
}


SQLHelper---赵晓虎(简洁,全面)的更多相关文章

  1. asp.net 建多个项目实现三层的实例——读取一张表中的记录条数

    学习asp.net两周,通过学习发现,.net和php之间的区别还是蛮大的,比php要复杂一些,开始学习的有些吃力,后来跟着传智播客里的老师学习,渐渐的学到了一些东西. 今天要记录一下.net里的简单 ...

  2. JavaScript函数的4种调用方法详解

    在JavaScript中,函数是一等公民,函数在JavaScript中是一个数据类型,而非像C#或其他描述性语言那样仅仅作为一个模块来使用.函数有四种调用模式,分别是:函数调用形式.方法调用形式.构造 ...

  3. QL Server 实用脚本

    use MyFirstDB; -- 主要内容 -- SQL Server 实用脚本 -- 1.case语句 -- 2.子查询 -- 3.连接查询 -- 4.脚本变量与流程控制(选择与循环等) -- 5 ...

  4. Delegate(委托与事件)

    Delegate可以当它是一个占位符,比如你在写代码的时候并不知道你将要处理的是什么.你只需要知道你将要引入的参数类型和输出类型是什么并定义它即可.这就是书本上所传达的方法签名必须相同的意思. 系统自 ...

  5. XML文件注意问题

    一.Elements和Descendant Elements 相当于root节点下的子节点,Desendant元素相当于root节点下的所有子节点(包括root.elments下个子节点也包括root ...

  6. JavaScript高级之函数的四种调用形式

    主要内容 分析函数的四种调用形式 弄清楚函数中this的意义 明确构造函对象的过程 学会使用上下文调用函数 了解函数的调用过程有助于深入学习与分析JavaScript代码. 本文是JavaScript ...

  7. 你不知道的JavaScript--Item8 函数,方法,构造函数调用

    1.函数调用 Function绝对是JavaScript中的重中之重.在JavaScript中,Function承担了procedures, methods, constructors甚至是class ...

  8. qconbeijing2017

    http://2017.qconbeijing.com/schedule 第一天 (2017年4月16日/星期日)   签到 专题 主题演讲 快速进化的容器生态 微服务与 DevOps 最佳实践(厂商 ...

  9. python基础学习(一)

    一,Python介绍 1,python的出生与应用 python的创始人为吉多·范罗苏姆(Guido van Rossum).1989年的圣诞节期间,吉多·范罗苏姆(中文名字:龟叔)为了在阿姆斯特丹打 ...

随机推荐

  1. 【Octave】柱面投影简析

    ========================我是分割线========================== 在做全景拼接的时候,为了保持图片中的空间约束与视觉的一致性,需要做一定的预处理,可以是球 ...

  2. bzoj-3170 3170: [Tjoi 2013]松鼠聚会(计算几何)

    题目链接: 3170: [Tjoi 2013]松鼠聚会 Time Limit: 10 Sec  Memory Limit: 128 MB Description 有N个小松鼠,它们的家用一个点x,y表 ...

  3. 《The Django Book》实战--第二章--动态网页基础

    这章演示了一些最基本的Django开发动态网页的实例,由于版本不一样,我用的是Django 1.,6.3,有些地方按书上的做是不行的,所以又改了一些,写出来让大家参考. 这是一个用python写的一个 ...

  4. UVA 10405 Longest Common Subsequence --经典DP

    最长公共子序列,经典问题.算是我的DP开场题吧. dp[i][j]表示到s1的i位置,s2的j位置为止,前面最长公共子序列的长度. 状态转移: dp[i][j] = 0                 ...

  5. Android代码规范----按钮单击事件的四种写法

    [前言] 按钮少的时候用第三种的匿名内部类会比较快,比如写demo测试的时候或者登陆界面之类. 按钮多的时候一般选择第四种写法. 一.第一种写法:在XML文件中声明onClick属性(很少用) 在XM ...

  6. C# Reflection Type/MethodInfo

    C#反射 在C#的反射中,可以通过Type来执行类中的某个方法,也可以通过MethodInfo来执行方法 三种调用方法 下面的示例中使用了三种方法来执行方法 两个类:Class1和Demo1,通过反射 ...

  7. 2703 奶牛代理商 XII

    2703 奶牛代理商 XII  时间限制: 1 s  空间限制: 32000 KB  题目等级 : 黄金 Gold 题解       题目描述 Description 小徐从美国回来后,成为了USAC ...

  8. FTP登录/目录破解

    l临时简单的验证,还需要优化... 登录: import ftplib usr = open('usr.txt','r') ftp = ftplib.FTP("*************&q ...

  9. MySQL基础 - 外键和约束

    在工作中经常会遇到不少不同的观点,比如对于数据库来说那就是是否要设置外键,设置外键的理由自然不必多说,而不设置外键的理由多半为设置外键影响性能,但就目前工作来讲,还没有涉及到因为外键而引发的数据库瓶颈 ...

  10. 【网站搭建教程】黑手VIP卡盟搭建教程(无KEY)

    黑手VIP卡盟搭建教程(无KEY)教程介绍:第一课 卡盟介绍与课程流程.exe第七课 卡盟源码的搜集与选择_.exe第三课 卡盟域名之注册.exe第九课 IIS的本机架设_.exe第二课 卡盟域名之选 ...