/*=============================================================

*.net连接数据库常用方法

*Author : dongny,Li

*E-mail : xing.dong.li@163.com

*Edition: Beta 1.0

*=============================================================*/

using System;

using System.Collections.Generic;

using System.Text;

using System.Configuration;

using System.Data.SqlClient;

using System.Data;

namespace TreeViewHelper

{

public class SqlDBHelper

{

//在配置文件Web.Config中获取连接字符串

public static string connectionStr =ConfigurationManager.ConnectionStrings["connectionStr"].ConnectionString;

/// <summary>

/// 执行增删改T-SQL语句,返回执行成功与否

/// </summary>

/// <param name="strSql">T-SQL语句或存储过程名称</param>

/// <paramname="cmdType">T-SQL语句类别</param>

/// <param name="param">参数列表</param>

/// <returns>返回值为:true/false</returns>

public static bool DoExecuteNonQuery(string strSql, CommandType cmdType,params SqlParameter[] param)

{

using (SqlConnection con = new SqlConnection(connectionStr))

{

try

{

con.Open();

SqlCommand com = newSqlCommand(strSql, con);

com.CommandType = cmdType;

if (param.Length > 0)

com.Parameters.AddRange(param);

int flag =com.ExecuteNonQuery();

return flag > 0 ? true :false;

}

catch(Exception ex)

{

throw newException("SQL Connection Faile,Bring Error DoExecuteNonQuery :"+ex.Message);

}

finally

{

con.Close();

}

}

}

/// <summary>

/// 执行查询T-SQL语句,返回SqlDataReader对象

/// </summary>

/// <param name="strSql">T-SQL语句或存储过程</param>

/// <param name="cmdType">T-SQL语句类型</param>

/// <param name="param">参数列表</param>

/// <returns>SqlDataReader对象</returns>

public static SqlDataReader GetSqlDataReader(string strSql, CommandTypecmdType, params SqlParameter[] param)

{

SqlConnection con = new SqlConnection(connectionStr);

SqlDataReader sdr = null;

SqlCommand com = null;

try

{

con.Open();

com = new SqlCommand();

com.Connection = con;

com.CommandType = cmdType;

com.CommandText = strSql;

if (param.Length > 0)

com.Parameters.AddRange(param);

sdr =com.ExecuteReader(CommandBehavior.CloseConnection);

return sdr;

}

catch(Exception ex)

{

con.Close();

throw new Exception("SQLConnection Faile ,Bring Error GetSqlDataReader: " + ex.Message);

}

finally

{

com.Dispose();

}

}

/// <summary>

/// 执行查询T-SQL语句,返回DataSet

/// </summary>

/// <param name="strSql">T-SQL语句或存储过程</param>

/// <param name="cmdType">T-SQL语句类型</param>

/// <param name="param">参数列表</param>

/// <returns>DataSet对象</returns>

public static DataSet GetDataSet(string strSql, CommandType cmdType,params SqlParameter[] param)

{

using (SqlConnection con = new SqlConnection(connectionStr))

{

SqlDataAdapter sda = null;

try

{

con.Open();

SqlCommand com = newSqlCommand(strSql, con);

com.CommandType = cmdType;

com.Parameters.AddRange(param);

sda = newSqlDataAdapter(com);

DataSet ds = new DataSet();

sda.Fill(ds);

return ds;

}

catch(Exception ex)

{

throw newException("SQL Connection Faile ,Bring error GetDataSet: " +ex.Message);

}

finally

{

sda.Dispose();

con.Close();

}

}

}

/// <summary>

/// 执行查询T-SQL语句,返回DataTable

/// </summary>

/// <param name="strSql">T-SQL语句或存储过程</param>

/// <param name="cmdType">T-SQL语句类型</param>

/// <param name="param">参数列表</param>

/// <returns>DataTable对象</returns>

public static DataTable GetDataTable(string strSql, CommandType cmdType,params SqlParameter[] param)

{

using (SqlConnection con = new SqlConnection(connectionStr))

{

SqlDataAdapter sda = null;

try

{

con.Open();

SqlCommand com = newSqlCommand(strSql, con);

com.CommandType = cmdType;

com.Parameters.AddRange(param);

sda = newSqlDataAdapter(com);

DataTable dt = newDataTable();

sda.Fill(dt);

return dt;

}

catch(Exception ex)

{

throw newException("SQL Connection Faile ,Bring error GetDataTable: " +ex.Message);

}

finally

{

sda.Dispose();

con.Close();

}

}

}

/// <summary>

/// 执行查询T-SQL语句,返回单行记录

/// </summary>

/// <param name="strSql">T-SQL语句或存储过程</param>

/// <param name="cmdType">T-SQL语句类型</param>

/// <param name="param">参数列表</param>

/// <returns>返回Object对象</returns>

public static Object DoExecuteScalar(string strSql, CommandType cmdType,params SqlParameter[] param)

{

Object obj = null;

using (SqlConnection con = new SqlConnection(connectionStr))

{

SqlCommand com = newSqlCommand(strSql, con);

try

{

com.CommandType = cmdType;

com.Parameters.AddRange(param);

com.Connection.Open();

obj = com.ExecuteScalar();

return obj;

}

catch(Exception ex)

{

throw newException("SQL Connection Faile , Bring Error DoExecuteScalar: " +ex.Message);

}

finally

{

com.Dispose();

con.Close();

}

}

}

}

}

SqlDBHelper常用方法的更多相关文章

  1. 前端开发:Javascript中的数组,常用方法解析

    前端开发:Javascript中的数组,常用方法解析 前言 Array是Javascript构成的一个重要的部分,它可以用来存储字符串.对象.函数.Number,它是非常强大的.因此深入了解Array ...

  2. Jquery元素选取、常用方法

    一:常用的选择器:(李昌辉) 基本选择器 $("#myDiv") //匹配唯一的具有此id值的元素 $("div") //匹配指定名称的所有元素 $(" ...

  3. python浅谈正则的常用方法

    python浅谈正则的常用方法覆盖范围70%以上 上一次很多朋友写文字屏蔽说到要用正则表达,其实不是我不想用(我正则用得不是很多,看过我之前爬虫的都知道,我直接用BeautifulSoup的网页标签去 ...

  4. C# Webbrowser 常用方法及多线程调用

    设置控件的值 /// <summary> /// 根据ID,NAME双重判断并设置值 /// </summary> /// <param name="tagNa ...

  5. list,tuple,dict,set常用方法

    Python中list,tuple,dict,set常用方法 collections模块提供的其它有用扩展类型 from collections import Counter from collect ...

  6. 记录yii2-imagine几个常用方法

    记录yii2-imagine几个常用方法: //压缩 Image::thumbnail('@webroot/img/test-image.jpg', 120, 120)->save(Yii::g ...

  7. DOM常用方法总结

    DOM(Document Object Model:文档对象模型)为javascript中的一部分,它为访问和修改html文档或xml文档提供了一些编程接口,DOM以对象的形式来描述文档中的内容,以树 ...

  8. JSP内置对象及常用方法

    jsp九大内置对象及四个作用域: 何为作用域 先让我们看看效果: 大概流程是这样的,我们访问index.jsp的时候,分别对pageContext, request, session,applicat ...

  9. java中集合类中Collection接口中的Map接口的常用方法熟悉

    1:Map接口提供了将键映射到值的对象.一个映射不能包含重复的键:每个键最多只能映射到一个值.Map接口中同样提供了集合的常用方法. 2:由于Map集合中的元素是通过key,value,进行存储的,要 ...

随机推荐

  1. Summary of Amazon Marketplace Web Service

    Overview Here I want to summarize Amazon marketplace web service (MWS or AMWS) that can be used for ...

  2. Delphi XE5教程10:Delphi字符集

    内容源自Delphi XE5 UPDATE 2官方帮助<Delphi Reference>,本人水平有限,欢迎各位高人修正相关错误!也欢迎各位加入到Delphi学习资料汉化中来,有兴趣者可 ...

  3. AS3 - 数组Array的几个常用方法(附样例)

    AS3 - 数组Array的几个常用方法(附样例) 2015-03-30 10:39发布:hangge浏览:241   Flex/Flash开发中,经常会使用到数组,下面总结了一些数组的常用方法. 1 ...

  4. WPF中的Style

    一.Style基础知识 构成Style最重要的两种元素是Setter和Trigger Setter类帮助我们设置控件的静态外观风格 Trigger类帮助我们设置控件的行为风格 Setter类的Prop ...

  5. useradd命令详解

    功能说明:建立用户帐号.语 法:useradd [-mMnr][-c <备注>][-d <登入目录>][-e <有效期限>][-f <缓冲天数>][-g ...

  6. [ios]ipad下的splitViewController 让你的APP看起来酷酷的!

    在ipad下可以使用splitViewController splitViewController下包含两个viewController 这是一种将屏幕一分为二的方式. 在水平状态下会出现成两个左右两 ...

  7. 【CocoaPods】CocoaPods基本安装教程

    CocoaPods是什么,有什么用,怎么来等等我就不说了.反正就是一个管理第三方开源框架的~ 1. 配置前 - 本地安装好Ruby环境 2. 安装命令 -> sudo gem install c ...

  8. Ubuntu 14.04 安装 Xilinx ISE 14.7 全过程

    生命在于折腾. 这个帖子作为我安装xilinx ISE 14.7版本一个记录.希望给需要的人一些帮助,这些内容绝大部分也是来源于互联网. 软硬件: lsb_release -a No LSB modu ...

  9. 微软职位内部推荐-Senior SDE for Big Data

    微软近期Open的职位: Title: Senior SDE The Big Data Tooling team looking for a talented and passionate devel ...

  10. easyui的datagrid和panel如何让标题动态改变?

    解决方法: 用$(this).datagrid("getPanel").panel("setTitle","new title").$(th ...