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. 如何判断两个String是否是Anagrams_java实现

    Anagrams:是颠倒字母顺序的字符串 本文提供三个方法,分别分析时间空间复杂度 方法一:暴力遍历 时间复杂度:O(n^2) 方法二:基于排序算法,Sorting的时间复杂度是O(n*log(n)) ...

  2. 【Android UI设计与开发】5.底部菜单栏(二)使用Fragment实现底部菜单栏

    既然 Fragment 取代了TabActivity,当然 TabActivity 的能实现的菜单栏,Fragment 当然也能实现.主要其实就是通过菜单栏的点击事件切换 Fragment 的显示和隐 ...

  3. DoTween(HOTween V2) 教程

    DoTween资料 官方网站:http://dotween.demigiant.com/ 下载地址:http://dotween.demigiant.com/download.php 快速开始:htt ...

  4. [ORACLE错误]oracle 不能更新 PL/SQL 点击“edit data”报“ these query results are not updateable”

    你可以选择在查询语句的最后加上 for update,就可以打开编辑锁,直接修改数据. 而在默认查询下,点击Edit data,会报错:The query results are not update ...

  5. 每日一语:What is he getting at?

    What is he getting at? 他讲这话是什么意思? 2015-1-12

  6. Eclipse去除JavaScript验证错误

    这篇文章主要是对Eclipse去除js(JavaScript)验证错误进行了介绍.在Eclipse中,js文件常常会报错.可以通过如下几个步骤解决 第一步: 去除eclipse的JS验证: 将wind ...

  7. 创建租房网House脚本

    USE MASTER GO EXEC XP_CMDSHELL 'MKDIR E:\HOUSE1' GO SET NOCOUNT ON----不显示影响行数 IF EXISTS(SELECT * FRO ...

  8. Saltstack-自动化部署

    Saltstack概述 Salt一种全新的基础设施管理方式,部署轻松,在几分钟内可运行起来,扩展性好,很容易管理上万台服务器,速度够快,服务器之间秒级通讯. salt底层采用动态的连接总线, 使其可以 ...

  9. ST3插件——PlainTasks的使用

    今天看到一个有意思的ST3插件,可以进行简单的任务管理. 安装很简单:ctrl + shift + p,输入install回车,再输入plaintasks回车即可. 以下是一些支持的操作,更多的操作请 ...

  10. IBatis.net介绍

    IBatis.net介绍 IBatis.net 是2001年发起的开源项目,它是一个轻量级的ORM框架,现在IBatisNET已经是属于Apache下的一个子项目了,最新版本是1.6.2. 官方网站: ...