C# 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 FirstBI
{
public abstract class SqlHelpertrain//定义为abstract抽象类,不能被实例化,在应用时直接调用
{
/*1.获取数据库连接字符串;
* 2.Connection 链接绑定,open/close;
* 3.实例化一个Command命令,给定命令执行的超时时间 ,命令执行的连接;命令的类型(增/删/改/查)
* ,是否带事务,执行用到哪些参数,还有最重要的命令执行的sql字符串;
* 4.SqlDataAdapter承接命令返回的结果集
*/
private static int TimeOut = ;
private static string connStrs = ConfigurationManager.ConnectionStrings["FirstBI.Properties.Settings.BaseERPConnectionString"].ConnectionString;
/// <summary>
/// 获取SqlCommand
/// </summary>
/// <param name="conn"></param>
/// <param name="cmdType"></param>
/// <param name="tran"></param>
/// <param name="sqlParams"></param>
/// <returns></returns>
public static SqlCommand GetSqlCommand(string sql, SqlConnection conn, CommandType cmdType, SqlTransaction tran, params SqlParameter[] sqlParams)
{
SqlCommand cmd = new SqlCommand(sql, conn);
cmd.CommandTimeout = TimeOut;
cmd.CommandType = cmdType;
if (tran != null)
cmd.Transaction = tran;
if (sqlParams != null && sqlParams.Length > )
cmd.Parameters.AddRange(sqlParams);
return cmd;
}
/// <summary>
/// DataTable
/// </summary>
/// <param name="sql"></param>
/// <param name="cmdType"></param>
/// <param name="tran"></param>
/// <param name="sqlParams"></param>
/// <returns></returns>
public static DataTable GetDataTable(string sql, CommandType cmdType, SqlTransaction tran, params SqlParameter[] sqlParams)
{
using (SqlConnection conn = new SqlConnection(connStrs))
{
try
{
conn.Open();
using (SqlCommand cmd = GetSqlCommand(sql, conn, cmdType, tran, sqlParams))
{
using (SqlDataAdapter da = new SqlDataAdapter(cmd))
{
DataTable dt = new DataTable();
da.Fill(dt);
return dt;
}
} }
catch (SqlException ex)
{
StringBuilder log = new StringBuilder();
log.Append("查询数据错误:");
log.Append(ex);
throw new Exception(log.ToString());
}
finally
{
conn.Close();
}
}
}
/// <summary>
/// DataSet
/// </summary>
/// <param name="sql"></param>
/// <param name="cmdType"></param>
/// <param name="tran"></param>
/// <param name="sqlParams"></param>
/// <returns></returns>
public static DataSet GetDataSet(string sql, CommandType cmdType, SqlTransaction tran, params SqlParameter[] sqlParams)
{
using (SqlConnection conn = new SqlConnection(connStrs))
{
using (SqlCommand cmd = GetSqlCommand(sql, conn, cmdType, tran, sqlParams))
{
try
{
conn.Open();
using (SqlDataAdapter da = new SqlDataAdapter(cmd))
{
DataSet ds = new DataSet();
da.Fill(ds);
return ds;
}
}
catch (SqlException ex)
{
StringBuilder log = new StringBuilder();
log.Append("查询数据错误:");
log.Append(ex);
throw new Exception(log.ToString());
}
finally
{
conn.Close();
}
}
}
}
/// <summary>
/// 返回影响的行数
/// </summary>
/// <param name="sql"></param>
/// <param name="cmdType"></param>
/// <param name="tran"></param>
/// <param name="sqlParams"></param>
/// <returns></returns>
public static int ExecNonQuery(string sql, CommandType cmdType, SqlTransaction tran, params SqlParameter[] sqlParams)
{
/*定义: SqlCommand cmd = new SqlCommand();//或者SqlCommand cmd = new SqlConnection().CreateCommand(); 注意参数
cmd.CommandType = CommandType.StoredProcedure; //存储过程
cmd.CommandType = CommandType.Text; //sql语句
cmd.CommandType = CommandType.TableDirect; System.Data.CommandType.TableDirect表示要执行的是表
,此时,cmd.CommandText 的值应该是要查询表的的名称。查询结果返回的是整个表。
*/
int count = ;
using (SqlConnection conn = new SqlConnection(connStrs))
{
using (SqlCommand cmd = GetSqlCommand(sql, conn, cmdType, tran, sqlParams))
{ try
{
conn.Open(); if (cmdType == CommandType.StoredProcedure)
cmd.Parameters.AddWithValue("@RETURN_VALUE", "").Direction = ParameterDirection.ReturnValue;
count = cmd.ExecuteNonQuery();
if (count <= )
if (cmdType == CommandType.StoredProcedure)
count = (int)cmd.Parameters["@RETURN_VALUE"].Value;
}
catch (SqlException ex)
{
StringBuilder log = new StringBuilder();
log.Append("查询数据错误:");
log.Append(ex);
throw new Exception(log.ToString());
}
finally
{
conn.Close();
}
}
}
return count;
}
//返回查询结果的第一行第一列
public static object QueryScalar(string sql, CommandType cmdType, SqlTransaction tran, params SqlParameter[] sqlParams)
{
using (SqlConnection conn = new SqlConnection(connStrs))
{
using (SqlCommand cmd = GetSqlCommand(sql, conn, cmdType, tran, sqlParams))
{
try
{
conn.Open();//创建cmd之前或之后Open都是可以的
return cmd.ExecuteScalar();
}
catch (SqlException ex)
{
StringBuilder log = new StringBuilder();
log.Append("查询数据出错:");
log.Append(ex);
throw new Exception(log.ToString());
}
finally
{
conn.Close();
}
}
}
}
/// <summary>
/// 使用完应关闭Reader;因为SQLDataReader为在线操作数据库,所以这个封装的方法中不能关闭连接;
/// </summary>
/// <param name="sql"></param>
/// <param name="cmdType"></param>
/// <param name="tran"></param>
/// <param name="sqlParams"></param>
/// <returns></returns>
public static SqlDataReader GetDataReader(string sql, CommandType cmdType, SqlTransaction tran, params SqlParameter[] sqlParams)
{
//SqlDataReader要求,它读取数据的时候有,它独占它的SqlConnection对象,而且SqlConnection必须是Open状态
//SqlDataReader与SqlDataAdapter的区别:SqlDataReader为在线操作数据库,SqlDataAdapter为离线操作(打开连接获取数据集之后关闭连接,然后离线操作数据库,然后再打开连接将数据更新到数据库)
SqlConnection conn = new SqlConnection(connStrs);//不可以使用using
SqlCommand cmd = GetSqlCommand(sql, conn, cmdType, tran, sqlParams);
try
{
conn.Open();
//CommandBehavior.CloseConnection当SqlDataReader释放的时候,顺便把SqlConnection对象也释放掉
return cmd.ExecuteReader(CommandBehavior.CloseConnection);//在执行该命令时,如果关闭关联的 DataReader 对象,则关联的 Connection 对象也将关闭
}
catch (SqlException ex)
{
conn.Close();//异常时要关闭连接
StringBuilder log = new StringBuilder();
log.Append("查询数据错误:");
log.Append(ex);
throw new Exception(log.ToString());
}
}
}
}
C# sqlhelper 整理的更多相关文章
- 自用类库整理之SqlHelper和MySqlHelper
自用类库整理之SqlHelper和MySqlHelper 自用的SQLHelper和MySqlHelper,除一些通用方法外,封装了一些很实用的批量操作方法,简单介绍下 SqlHelper Execu ...
- [转]自用类库整理之SqlHelper和MySqlHelper
本文转自:http://www.cnblogs.com/lzrabbit/p/3287155.html 自用的SQLHelper和MySqlHelper,除一些通用方法外,封装了一些很实用的批量操作方 ...
- 整理出一个比较实用的SqlHelper类 满足大多数情况的使用
/// <summary> /// SqlHelper类 by zy 2016-3-11 /// </summary> public sealed class SqlHelpe ...
- Markdown 语法整理
Markdown 语法整理 白宁超 2015年7月24日14:57:49 一.字体设置 A First Level Header == A Second Level Header -- # 标题 ## ...
- ADO.NET复习——自己编写SqlHelper类
今天复习了一次ADO.NET基础,整理一下自己的认为的重点: 编写SqlHelper类,方便我们执行数据库语句,这时可以直接调用封装在SqlHelper类的方法.现在大多数公司面试的时候,给你的面试题 ...
- ASP.NET MVC5 及 EF6 学习笔记 - (目录整理)
个人从传统的CS应用开发(WPF)开始转向BS架构应用开发: 先是采用了最容易上手也是最容易搞不清楚状况的WebForm方式入手:到后面就直接抛弃了服务器控件的开发方式,转而采用 普通页面+Ajax+ ...
- 数据库操作类《SqlHelper》
一.背景 在看了一本书叫<Visual Studio 2010(C#)Windows数据库项目开发>后,觉得很多编程技术需要积累,因为一个简单的项目里包含的技术太多了,容易忘记.每次需要用 ...
- SqlHelper DBHelper
根据自己项目的开发需要,整理了一个SqlHelper类 相比较网上通用的SqlHelper类方法主要有一下几点的不同: 1.因为要操作多个数据库,所以数据库连接字符串没有写死到方法里,作为参数提供出来 ...
- 【转】.NET(C#):浅谈程序集清单资源和RESX资源 关于单元测试的思考--Asp.Net Core单元测试最佳实践 封装自己的dapper lambda扩展-设计篇 编写自己的dapper lambda扩展-使用篇 正确理解CAP定理 Quartz.NET的使用(附源码) 整理自己的.net工具库 GC的前世与今生 Visual Studio Package 插件开发之自动生
[转].NET(C#):浅谈程序集清单资源和RESX资源 目录 程序集清单资源 RESX资源文件 使用ResourceReader和ResourceSet解析二进制资源文件 使用ResourceM ...
随机推荐
- XPath简介及节点
XPath是一门在XML文档中查找信息的语言. XPath可用来在XML文档中对元素和属性进行遍历. XPath使用路径表达式在XML文档中进行导航. XPath路径表达式:XPath使用路径表达式来 ...
- LAB2
任务1: 效果:HelloWorld 好像完全按视频做就行了 学会了:把glassfish改好了,能跑 没学会:视频里的解说不懂在干嘛,得再看看 任务2 效果:intersetingpicture要求 ...
- Yii2增删改查
Controller <?php namespace frontend\controllers; use frontend\models\User; use yii\data\Paginatio ...
- KD-树(下)
来自于https://zhuanlan.zhihu.com/p/23966698 构造 kd 树的例子 上面抽象的定义和算法确实是很不好理解,举一个例子会清楚很多.首先随机在 中随机生成 13 个点作 ...
- 决策树模型组合之随机森林与GBDT(转)
版权声明: 本文由LeftNotEasy发布于http://leftnoteasy.cnblogs.com, 本文可以被全部的转载或者部分使用,但请注明出处,如果有问题,请联系wheeleast@gm ...
- 简单易用的图像库stb_image
最近又回到了选择图像库的老问题上,之前用过FreeImage,DevIL,libpng. FreeImage的问题是他的Licence有点迷,双证书,除了GPL还有个自己的没读懂,不商用的话随便折腾, ...
- linux系统下载pycharm
如何下载pycharm安装包? 你可以通过访问 https://www.jetbrains.com/pycharm/download/#section=linux 获取安装包,如果是新手建议使用社区版 ...
- Avoid Inputing Password While Pushing/Pulling Git Project
If we add public key in our git account, we can pull/push project easily without password. However, ...
- SSM_CRUD新手练习(9)显示分页数据
我们已经做好了用来显示数据的分页模板,现在只需要将我们从后台取出的数据填充好,显示出来. 我们使用<c:forEach>标签循环取出数据,所以需要先导入JSTL标签库 <%@ tag ...
- PHP 文件处理----fopen(),fclose(),feof(),fgets(),fgetc()
fopen() 函数用于在 PHP 中打开文件. 打开文件 fopen() 函数用于在 PHP 中打开文件. 此函数的第一个参数含有要打开的文件的名称,第二个参数规定了使用哪种模式来打开文件: < ...