几次装机,Notes已烟消云散,近日因为Node.js死活搞不定,无奈装机,备份好的东东,没想到磁盘扇区出现异常,可能是PE启动盘的病毒,只好将磁盘全部重新分区,恢复数据也懒得恢复了,日积月累关乎将来的开发效率,还好处于懵懂阶段。笔记一大堆,记忆力又不怎么好,所以web+log=blog;

SqlHelper类

using System;

using System.Collections.Generic;

using System.Configuration;

using System.Data;

using System.Data.SqlClient;

using System.Linq;

using System.Text;

using System.Threading.Tasks;

namespace DAL

{

/// <summary>

/// SqlHelper类 by zy 2016-3-11

/// </summary>

public  class SqlHelper

{
     //如果项目中只连接了一个数据库 那么可以在此定义一个固定的连接字符串

​    public static string ConnectionStr { get; } =

​        ConfigurationManager.ConnectionStrings["connStr"].ConnectionString;

​    public static string ConnStr()

​    {

​        return ConfigurationManager.ConnectionStrings["connStr"].ConnectionString;

​    }

​    #region ExecuteNonQuery

​    /// <summary>

​    /// 执行sql语句 返回受影响行数

​    /// </summary>

​    /// <param name="connectionString">连接字符串</param>

​    /// <param name="cmdType">command类型</param>

​    /// <param name="cmdText">sql语句</param>

​    /// <param name="commandParameters">参数</param>

​    /// <returns></returns>

​    public static int ExecuteNonQuery(string connectionString, CommandType cmdType, string cmdText,

​        params SqlParameter[] commandParameters)

​    {

​        SqlCommand cmd = new SqlCommand();

​        using (SqlConnection conn = new SqlConnection(connectionString))

​        {

​            PrepareCommand(cmd, conn, null, cmdType, cmdText, commandParameters);

​            int val = cmd.ExecuteNonQuery();

​            cmd.Parameters.Clear();

​            return val;

​        }

​    }

​    /// <summary>

​    /// 执行sql语句 返回当前插入的记录id(其实是ExecuteScalar转换成id返回)

​    /// </summary>

​    /// <param name="connectionString">连接字符串</param>

​    /// <param name="cmdType">command类型</param>

​    /// <param name="cmdText">sql语句</param>

​    /// <param name="returnID">返回id</param>

​    /// <param name="commandParameters">参数</param>

​    /// <returns></returns>

​    public static int ExecuteNonQuery(string connectionString, CommandType cmdType, string cmdText,

​        out int returnID, params SqlParameter[] commandParameters)

​    {

​        SqlCommand cmd = new SqlCommand();

​        using (SqlConnection conn = new SqlConnection(connectionString))

​        {

​            returnID = 0;

​            PrepareCommand(cmd, conn, null, cmdType, cmdText, commandParameters);

​            returnID = (Int32) cmd.ExecuteScalar();

​            cmd.Parameters.Clear();

​            return returnID;

​        }

​    }

​    /// <summary>

​    /// 执行sql语句 返回受影响行数(数据库连接SqlConnection)

​    /// </summary>

​    /// <param name="connection">SqlConnection连接</param>

​    /// <param name="cmdType">command类型</param>

​    /// <param name="cmdText">sql语句</param>

​    /// <param name="commandParameters">参数</param>

​    /// <returns></returns>

​    public static int ExecuteNonQuery(SqlConnection connection, CommandType cmdType, string cmdText,

​        params SqlParameter[] commandParameters)

​    {

​        SqlCommand cmd = new SqlCommand();

​        PrepareCommand(cmd, connection, null, cmdType, cmdText, commandParameters);

​        int val = cmd.ExecuteNonQuery();

​        cmd.Parameters.Clear();

​        return val;

​    }

​    /// <summary>

​    /// 执行sql语句 返回受影响行数(事务SqlTransaction)

​    /// </summary>

​    /// <param name="trans">SqlTransaction事务</param>

​    /// <param name="cmdType">command类型</param>

​    /// <param name="cmdText">sql语句</param>

​    /// <param name="commandParameters">参数</param>

​    /// <returns></returns>

​    public static int ExecuteNonQuery(SqlTransaction trans, CommandType cmdType, string cmdText,

​        params SqlParameter[] commandParameters)

​    {

​        SqlCommand cmd = new SqlCommand();

​        PrepareCommand(cmd, trans.Connection, trans, cmdType, cmdText, commandParameters);

​        int val = cmd.ExecuteNonQuery();

​        cmd.Parameters.Clear();

​        return val;

​    }

​    #endregion

​    #region ExecuteScalar

​    /// <summary>

​    /// 执行sql语句 返回结果集第一行第一列

​    /// </summary>

​    /// <param name="connectionString">连接字符串</param>

​    /// <param name="cmdType">Command类型</param>

​    /// <param name="cmdText">sql语句</param>

​    /// <param name="commandParameters">参数</param>

​    /// <returns></returns>

​    public static object ExecuteScalar(string connectionString, CommandType cmdType, string cmdText,

​        params SqlParameter[] commandParameters)

​    {

​        SqlCommand cmd = new SqlCommand();

​        using (SqlConnection connection = new SqlConnection(connectionString))

​        {

​            PrepareCommand(cmd, connection, null, cmdType, cmdText, commandParameters);

​            object val = cmd.ExecuteScalar();

​            cmd.Parameters.Clear();

​            return val;

​        }

​    }

​    /// <summary>

​    /// 执行sql语句 返回结果集第一行第一列(事务)

​    /// </summary>

​    /// <param name="trans">SqlTransaction事务</param>

​    /// <param name="cmdType">Command类型</param>

​    /// <param name="cmdText">sql语句</param>

​    /// <param name="commandParameters">参数</param>

​    /// <returns></returns>

​    public static object ExecuteScalar(SqlTransaction trans, CommandType cmdType, string cmdText,

​        params SqlParameter[] commandParameters)

​    {

​        SqlCommand cmd = new SqlCommand();

​        PrepareCommand(cmd, trans.Connection, trans, cmdType, cmdText, commandParameters);

​        object val = cmd.ExecuteScalar();

​        cmd.Parameters.Clear();

​        return val;

​    }

​    /// <summary>

​    /// 执行sql语句 返回结果集第一行第一列(数据库连接)

​    /// </summary>

​    /// <param name="connection">SqlConnection连接</param>

​    /// <param name="cmdType">Command类型</param>

​    /// <param name="cmdText">sql语句</param>

​    /// <param name="commandParameters">参数</param>

​    /// <returns></returns>

​    public static object ExecuteScalar(SqlConnection connection, CommandType cmdType, string cmdText,

​        params SqlParameter[] commandParameters)

​    {

​        SqlCommand cmd = new SqlCommand();

​        PrepareCommand(cmd, connection, null, cmdType, cmdText, commandParameters);

​        object val = cmd.ExecuteScalar();

​        cmd.Parameters.Clear();

​        return val;

​    }

​    #endregion

​    #region ExecuteReader

​    /// <summary>

​    /// 执行sql语句 返回reader

​    /// </summary>

​    /// <param name="connectionString">连接字符串</param>

​    /// <param name="cmdType">command类型</param>

​    /// <param name="cmdText">sql语句</param>

​    /// <param name="commandParameters">参数</param>

​    /// <returns></returns>

​    public static SqlDataReader ExecuteReader(string connectionString, CommandType cmdType, string cmdText,

​        params SqlParameter[] commandParameters)

​    {

​        SqlCommand cmd = new SqlCommand();

​        SqlConnection conn = new SqlConnection(connectionString);

​        try

​        {

​            PrepareCommand(cmd, conn, null, cmdType, cmdText, commandParameters);

​            SqlDataReader rdr = cmd.ExecuteReader(CommandBehavior.CloseConnection);

​            cmd.Parameters.Clear();

​            return rdr;

​        }

​        catch

​        {

​            conn.Close();

​            throw;

​        }

​    }

​    #endregion

​    #region DataSet

​    /// <summary>

​    /// 执行sql语句 返回DataSet结果集(无参数)

​    /// </summary>

​    /// <param name="connectionString">连接字符串</param>

​    /// <param name="commandType">command类型</param>

​    /// <param name="commandText">sql语句</param>

​    /// <returns></returns>

​    public static DataSet ExecuteDataset(string connectionString, CommandType commandType, string commandText)

​    {

​        return ExecuteDataset(connectionString, commandType, commandText, (SqlParameter[]) null);

​    }

​    /// <summary>

​    /// 执行sql语句 返回DataSet结果集

​    /// </summary>

​    /// <param name="connectionString">连接字符串</param>

​    /// <param name="commandType">command类型</param>

​    /// <param name="commandText">sql语句</param>

​    /// <param name="commandParameters">参数</param>

​    /// <returns></returns>

​    public static DataSet ExecuteDataset(string connectionString, CommandType commandType, string commandText,

​        params SqlParameter[] commandParameters)

​    {

​        //创建数据库连接 完成后dispose

​        using (SqlConnection cn = new SqlConnection(connectionString))

​        {

​            cn.Open();

​            //根据数据库连接 调用具体方法

​            return ExecuteDataset(cn, commandType, commandText, commandParameters);

​        }

​    }

​    /// <summary>

​    /// 执行sql语句 返回DataSet结果集(数据库连接SqlConnection)

​    /// </summary>

​    /// <param name="connection">SqlConnection连接</param>

​    /// <param name="commandType">command类型</param>

​    /// <param name="commandText">sql语句</param>

​    /// <param name="commandParameters">参数</param>

​    /// <returns></returns>

​    public static DataSet ExecuteDataset(SqlConnection connection, CommandType commandType, string commandText,

​        params SqlParameter[] commandParameters)

​    {

​        //创建command

​        SqlCommand cmd = new SqlCommand();

​        //准备command对象

​        PrepareCommand(cmd, connection, (SqlTransaction) null, commandType, commandText, commandParameters);

​        //创建SqlDataAdapter和DataSet

​        SqlDataAdapter da = new SqlDataAdapter(cmd);

​        DataSet ds = new DataSet();

​        //把结果集装进dataset

​        da.Fill(ds);

​        //返回

​        return ds;

​    }

​    #endregion DataSet

​    #region DataTable

​    /// <summary>

​    /// 执行sql语句 返回DataTable结果集(无参数)

​    /// </summary>

​    /// <param name="connectionString">连接字符串</param>

​    /// <param name="commandType">command类型</param>

​    /// <param name="commandText">sql语句</param>

​    /// <returns></returns>

​    public static DataTable ExecuteDataTable(string connectionString, CommandType commandType, string commandText)

​    {

​        return ExecuteDataTable(connectionString, commandType, commandText, (SqlParameter[])null);

​    }

​    /// <summary>

​    /// 执行sql语句 返回DataTable结果集

​    /// </summary>

​    /// <param name="connectionString">连接字符串</param>

​    /// <param name="commandType">command类型</param>

​    /// <param name="commandText">sql语句</param>

​    /// <param name="commandParameters">参数</param>

​    /// <returns></returns>

​    public static DataTable ExecuteDataTable(string connectionString, CommandType commandType, string commandText,

​        params SqlParameter[] commandParameters)

​    {

​        using (SqlConnection cn = new SqlConnection(connectionString))

​        {

​            cn.Open();

​            return ExecuteDataTable(cn, commandType, commandText, commandParameters);

​        }

​    }

​    /// <summary>

​    /// 执行sql语句 返回DataTable结果集

​    /// </summary>

​    /// <param name="connection">SqlConnection连接</param>

​    /// <param name="commandType">command类型</param>

​    /// <param name="commandText">sql语句</param>

​    /// <param name="commandParameters">参数</param>

​    /// <returns></returns>

​    public static DataTable ExecuteDataTable(SqlConnection connection, CommandType commandType, string commandText,

​        params SqlParameter[] commandParameters)

​    {

​        SqlCommand cmd = new SqlCommand();

​        PrepareCommand(cmd, connection, (SqlTransaction) null, commandType, commandText, commandParameters);

​        SqlDataAdapter da = new SqlDataAdapter(cmd);

​        DataTable dt = new DataTable();

​        da.Fill(dt);

​        return dt;

​    }

​    #endregion DataTable

​    #region PrepareCommand

​    /// <summary>

​    /// 准备Command对象

​    /// </summary>

​    /// <param name="cmd">SqlCommand 对象</param>

​    /// <param name="conn">SqlConnection 对象</param>

​    /// <param name="trans">SqlTransaction 对象</param>

​    /// <param name="cmdType">Command 类型</param>

​    /// <param name="cmdText">sql语句</param>

​    /// <param name="cmdParms">参数</param>

​    private static void PrepareCommand(SqlCommand cmd, SqlConnection conn, SqlTransaction trans,

​        CommandType cmdType, string cmdText, SqlParameter[] cmdParms)

​    {

​        //打开SqlConnection连接

​        if (conn.State != ConnectionState.Open)

​            conn.Open();

​        //给Command的Connection CommandText设置值

​        cmd.Connection = conn;

​        cmd.CommandText = cmdText;

​        //如果是事务 设置事务

​        if (trans != null)

​            cmd.Transaction = trans;

​        //Command类型

​        cmd.CommandType = cmdType;

​        //Command参数

​        if (cmdParms != null)

​        {

​            foreach (SqlParameter parm in cmdParms)

​            {

​                //在此可以操作参数 比如把参数值里的英文逗号全部改为中文逗号 或者其他操作

​                switch (parm.SqlDbType)

​                {

​                    case SqlDbType.Char:

​                    case SqlDbType.NChar:

​                    case SqlDbType.NText:

​                    case SqlDbType.NVarChar:

​                    case SqlDbType.Text:

​                    case SqlDbType.VarChar:

​                        if (parm.Value != null && parm.Value != DBNull.Value && parm.ParameterName != "@SQLClause")

​                        {

​                            string tmp = parm.Value.ToString();

​                            tmp = tmp.Replace(",", ",");

​                            tmp = tmp.Replace("'", "'");

​                            parm.Value = tmp;

​                        }

​                        break;

​                }

//把参数添加到Command中的Parameters中
                 cmd.Parameters.Add(parm);
             }
         }
     }

#endregion

}

}

原文地址不得,忘记哪里CV的了。

ADO.Net笔记整理(一)的更多相关文章

  1. python学习笔记整理——字典

    python学习笔记整理 数据结构--字典 无序的 {键:值} 对集合 用于查询的方法 len(d) Return the number of items in the dictionary d. 返 ...

  2. 从0开始学Swift笔记整理(五)

    这是跟在上一篇博文后续内容: --Core Foundation框架 Core Foundation框架是苹果公司提供一套概念来源于Foundation框架,编程接口面向C语言风格的API.虽然在Sw ...

  3. Deep Learning(深度学习)学习笔记整理系列之(五)

    Deep Learning(深度学习)学习笔记整理系列 zouxy09@qq.com http://blog.csdn.net/zouxy09 作者:Zouxy version 1.0 2013-04 ...

  4. 学习ReactNative笔记整理一___JavaScript基础

    学习ReactNative笔记整理一___JavaScript基础 ★★★笔记时间- 2017-1-9 ★★★ 前言: 现在跨平台是一个趋势,这样可以减少开发和维护的成本.第一次看是看的ReactNa ...

  5. Deep Learning(深度学习)学习笔记整理系列之(八)

    Deep Learning(深度学习)学习笔记整理系列 zouxy09@qq.com http://blog.csdn.net/zouxy09 作者:Zouxy version 1.0 2013-04 ...

  6. Deep Learning(深度学习)学习笔记整理系列之(七)

    Deep Learning(深度学习)学习笔记整理系列 zouxy09@qq.com http://blog.csdn.net/zouxy09 作者:Zouxy version 1.0 2013-04 ...

  7. Deep Learning(深度学习)学习笔记整理系列之(六)

    Deep Learning(深度学习)学习笔记整理系列 zouxy09@qq.com http://blog.csdn.net/zouxy09 作者:Zouxy version 1.0 2013-04 ...

  8. Deep Learning(深度学习)学习笔记整理系列之(四)

    Deep Learning(深度学习)学习笔记整理系列 zouxy09@qq.com http://blog.csdn.net/zouxy09 作者:Zouxy version 1.0 2013-04 ...

  9. Deep Learning(深度学习)学习笔记整理系列之(三)

    Deep Learning(深度学习)学习笔记整理系列 zouxy09@qq.com http://blog.csdn.net/zouxy09 作者:Zouxy version 1.0 2013-04 ...

随机推荐

  1. Java基础差,需要怎么补

    本文首发于本博客 猫叔的博客,转载请申明出处 感谢sugar的提问:Java基础差,需要怎么补? 欢迎关注公众号:Java猫说 我整体的总结了一下,大致分为以下的几个点说一下: 1.善于使用搜索引擎 ...

  2. 安装centos5.x的基本优化配置

    1.添加账号

  3. loj#6073. 「2017 山东一轮集训 Day5」距离(树链剖分 主席树)

    题意 题目链接 Sol 首先对询问差分一下,我们就只需要统计\(u, v, lca(u, v), fa[lca(u, v)]\)到根的路径的贡献. 再把每个点与\(k\)的lca的距离差分一下,则只需 ...

  4. 浅谈AndroidGPU过度绘制、GPU呈现模式分析及相关优化

    在真机设备下有一个开发者选项,这个大家都知道,我们最常用的就打开'USB调试'功能,方便真机调试. 在这开发者选项中还有个选项,'调试GPU过度绘制' 这里选择第二个选项'显示过度绘制区域' 可以看到 ...

  5. python在sqlite动态创建表源码

    代码之余,将开发过程中经常用的代码片段备份一下,如下的代码是关于python在sqlite动态创建表的代码,应该能对各位有所用. import sqlite3 as db conn = db.conn ...

  6. Dart语言入门(一)

    Dart 语言介绍 Dart 是谷歌在 2011 年推出的编程语言,是一种结构化 Web 编程语言,允许用户通过 Chromium 中所整合的虚拟机(Dart VM)直接运行 Dart 语言编写的程序 ...

  7. Ubuntu 服务器443端口证书配置

    配置虚拟主机: cd /etc/apache2/sites-available 从默认的模板文件中复制过来一份进行自己的配置: sudo cp ./default-ssl.conf ./mysite1 ...

  8. SQL SERVER-创建Alwayson

    Failover Custer(AlwaysOn) 创建Failover Cluster和启动AlwaysOn 创建Failover Cluster 节点的个数要是奇数如果是偶数则要加一个仲裁磁盘.在 ...

  9. 海思uboot启动流程详细分析(一)

    第一阶段 start.S 首先我们可以在u-boot.lds中看到ENTRY(_start),即指定了入口_start,_start也就是整个start.S的最开始: 1. reset 在arch\a ...

  10. Gitlab管理网页老是500错误?增加物理内存,增加cpu吧

    上一篇 CentOS 7 系统下 GitLab 搭建 搭建时,是用的是1G内存, 访问gitlab管理网页非常慢,常常出现 500错误 查询后发现: Gitlab的运行对CPU是有要求的:2核心 支持 ...