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. Java 开发环境部署

    1.下载Java开发环境工具包JDK,下载地址:http://www.oracle.com/technetwork/java/javase/downloads/index.html 下载后,双击jdk ...

  2. js制作倒计时效果

    该程序可以计算任意指定的两个日期中间的差值. 本例子的指定日期是2017年1月1日,当前时间是2016年10月21日:计算它们之间的差值,在网页上显示如图所示: 关键部分代码: var nowtime ...

  3. selenium如何操作cookies实现免登录

    执行接口测试或者某些自动化测试时,为了避免每次访问接口都需要登录操作,可以用访问接口时,把cookies信息传过去. 思路是先登录一次页面,获取到cookies信息,把cookies信息保存到本地文件 ...

  4. 矩阵乘法 codevs 1287 矩阵乘法

    1287 矩阵乘法  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 黄金 Gold       题目描述 Description 小明最近在为线性代数而头疼,线性代数确实很抽象 ...

  5. vector中pair的排序方法

    直接上代码: bool judge(const pair<int,char> a, const pair<int ,char> b) { return a.first<b ...

  6. cnblog code syntaxhighlighter view

    wlw代码插件 测试多款 wlw插入代码插件 在博客园的代码高亮效果 1.Code Snippet 1: public override void Update() 2: { 3: base.Upda ...

  7. 我的Unity学习路线

    前言 上班的时间内都很忙在做项目,休息时间里闲下来了,却觉得没什么事做不自在.难道真是苦逼的命不会享受? 想了一下这一段时间以来的过程:先是重新看了一遍Unity的基础部分,然后买了<3D数学基 ...

  8. find命令错误提示路径必须在表达式之前

    在某些版本的linux下,通过find查找当前目录下所有后缀名jpg的文件,命令为find ./ -iname *.jpg 会出现“find: 路径必须在表达式之前”的错误提示.解决的方法有两种 a. ...

  9. Python版任意进制转换

    def decimalToAny(num,n): baseStr = {10:"a",11:"b",12:"c",13:"d&qu ...

  10. Windows 2008 R2 配置 DNS 实现二级域名

    本文内容 域名解析 准备工作 安装 DNS 服务器 建立 DNS 区域 建立主机头 服务器网络设置 测试二级域名 IIS 建立 Web 站点 其他 DNS 服务 域名解析 域名解析,是域名到 IP 地 ...