注意:代码直接Copy调用即可,SQLServer工具类跟我上一个Oracle工具类有所不同,区别在于调用存储过程中时参数的使用,无需输入对应存储游标名称

特点:根据用户传入的参数类型来识别存储中对应的参数数据类型

        /// <summary>
///基於.net( 向下兼容4.0)開發 SQLServerDBHelper工具類
///<para>作者: 会害羞的青蛙</para>
///<para>時間: 2019-12-6</para>
/// </summary>
public class SQLServerDBHelper
{
/// <summary>
/// 執行SQL語句返回DataTable
/// </summary>
/// <param name="SQL">SQL語句</param>
/// <param name="DBUrl">數據庫鏈接地址</param>
/// <returns></returns>
public DataTable GetDataTableBySQL(string SQL, string DBUrl)
{
// 获取与数据库的连接对象並且绑定连接字符串
SqlConnection conn = new SqlConnection(DBUrl);
conn.Open();//打開資源
//获取数据库操作对象
SqlCommand cmd = conn.CreateCommand();
try
{
cmd.CommandText = SQL;
SqlDataAdapter adapter = new SqlDataAdapter(cmd);
DataTable dataTable = new DataTable();
dataTable.TableName = "數據集";
adapter.Fill(dataTable);
cmd.Dispose();//釋放資源
conn.Dispose();//釋放資源
conn.Close();//關閉
return dataTable;
}
catch (Exception ex)
{
cmd.Dispose();//釋放資源
conn.Dispose();//釋放資源
conn.Close();//關閉
throw ex;
}
}
/// <summary>
/// 執行非查詢的SQL語句
/// </summary>
/// <param name="SQL">SQL語句</param>
/// <param name="DBUrl">數據庫鏈接地址</param>
/// <returns></returns>
public int GetNonQueryBySQL(string SQL, string DBUrl)
{
// 获取与数据库的连接对象並且绑定连接字符串
SqlConnection conn = new SqlConnection(DBUrl);
conn.Open();//打開資源
//获取数据库操作对象
SqlCommand cmd = conn.CreateCommand();
try
{
cmd.CommandText = SQL;
int num = cmd.ExecuteNonQuery();
cmd.Dispose();//釋放資源
conn.Dispose();//釋放資源
conn.Close();//關閉
return num;
}
catch (Exception ex)
{
cmd.Dispose();//釋放資源
conn.Dispose();//釋放資源
conn.Close();//關閉
throw ex;
}
}
/// <summary>
/// 執行多條SQL語句,實現數據庫事務。
/// </summary>
/// <param name="SQLStringList">多條SQL語句</param>
/// <param name="BDUrl">數據庫鏈接地址</param>
public int GetNonQueryByManySQL(ArrayList SQLStringList, string BDUrl)
{
using (SqlConnection conn = new SqlConnection(BDUrl))
{
conn.Open();
SqlCommand cmd = new SqlCommand();
cmd.Connection = conn;
SqlTransaction tx = conn.BeginTransaction();
cmd.Transaction = tx;
try
{
int num = 0;
for (int i = 0; i < SQLStringList.Count; i++)
{
string SQL = SQLStringList[i].ToString();//獲取SQL語句
if (SQL.Trim().Length > 1)
{
cmd.CommandText = SQL;
num = cmd.ExecuteNonQuery();
}
tx.Commit();//提交事務
cmd.Dispose();//釋放資源
conn.Dispose();//釋放資源
conn.Close();//關閉 }
return num;//返回執行結果數量
}
catch (SqlException E)
{
tx.Rollback();//事務回滾
throw new Exception(E.Message);
}
}
}
/// <summary>
/// 調用存儲返回單個結果集
/// <para>obj使用方法:new{ v_data=value, v_data1=value1}</para>
/// <para>注意:obj中v_data為存儲參數名稱,value為對應的值,在SQLServer中沒有游標所以不需要定義輸出參數</para>
/// </summary>
/// <param name="storageName">存儲名稱</param>
/// <param name="DBUrl">數據庫鏈接地址</param>
/// <param name="obj">存儲參數對象</param>
/// <returns></returns>
public DataTable GetDataTableByStorageName(string storageName, string DBUrl, object obj)
{
// 获取与数据库的连接对象並且绑定连接字符串
SqlConnection conn = new SqlConnection(DBUrl);
conn.Open();//打開資源
//获取数据库操作对象
SqlCommand cmd = conn.CreateCommand();
try
{
cmd.CommandText = storageName;//存儲名稱
cmd.CommandType = CommandType.StoredProcedure;
PropertyInfo[] properties = obj.GetType().GetProperties(BindingFlags.Instance | BindingFlags.Public);//獲取object中的字段名和值
for (int i = 0; i < properties.Length; i++)
{//設定輸入的類型和值
cmd.Parameters.Add(properties[i].Name, GetOracleDbType(properties[i], obj)).Direction = ParameterDirection.Input;
cmd.Parameters[properties[i].Name].Value = properties[i].GetValue(obj, null);//賦值
}
DataTable dataTable = new DataTable();
SqlDataAdapter oda = new SqlDataAdapter(cmd);
oda.Fill(dataTable);
dataTable.TableName = "數據集";
cmd.Dispose();//釋放資源
conn.Dispose();//釋放資源
conn.Close();//關閉
return dataTable;
}
catch (Exception ex)
{
cmd.Dispose();//釋放資源
conn.Dispose();//釋放資源
conn.Close();//關閉
throw ex;
}
}
/// <summary>
/// 調用存儲返回String字符串信息(最後一個位置必須為String類型字符,位置不能顛倒)
/// <para>obj使用方法:new{ v_data=value, v_data1=value1,out_string=""}</para>
/// <para>注意:obj中v_data為存儲參數名稱,value為對應的值,out_string為輸出參數不需要輸入值</para>
/// </summary>
/// <param name="storageName"></param>
/// <param name="DBUrl"></param>
/// <param name="obj"></param>
/// <returns></returns>
public string GetStringDataByStorageName(string storageName, string DBUrl, object obj)
{
SqlConnection conn = new SqlConnection(DBUrl);
conn.Open();
//获取数据库操作对象
SqlCommand cmd = conn.CreateCommand();
try
{
cmd.CommandText = storageName;//存儲名稱
cmd.CommandType = CommandType.StoredProcedure;
PropertyInfo[] properties = obj.GetType().GetProperties(BindingFlags.Instance | BindingFlags.Public);//獲取object中的字段名和值
for (int i = 0; i < properties.Length; i++)
{
if (i == (properties.Length - 1))
{ //設定輸出的類型和值
cmd.Parameters.Add("@" + properties[i].Name, SqlDbType.NVarChar, short.MaxValue).Direction = ParameterDirection.Output;
cmd.Parameters["@" + properties[i].Name].Value = DBNull.Value;//賦值
}
else
{//設定輸入的類型和值
cmd.Parameters.Add(properties[i].Name, GetOracleDbType(properties[i], obj)).Direction = ParameterDirection.Input;
cmd.Parameters["@" + properties[i].Name].Value = properties[i].GetValue(obj, null);//賦值
}
}
cmd.ExecuteNonQuery();
string message = cmd.Parameters["@" + properties[properties.Length - 1].Name].Value.ToString();//獲取返回的值
cmd.Dispose();//釋放資源
conn.Dispose();//釋放資源
conn.Close();//關閉
return message;
}
catch (Exception ex)
{
cmd.Dispose();//釋放資源
conn.Dispose();//釋放資源
conn.Close();//關閉
throw ex;
}
}
/// <summary>
/// 調用存儲返回String字符串信息和DataTable數據表格(最後一個為輸出字符串,位置不能顛倒)
/// <para>obj使用方法:new{ v_data=value, v_data1=value1,out_string=""}</para>
/// <para>注意:obj中v_data為存儲參數名稱,value為對應的值,out_string為輸出參數不需要輸入值, 在SQLServer中沒有游標所以不需要定義輸出參數</para>
/// </summary>
/// <param name="storageName">存儲名稱</param>
/// <param name="DBUrl">數據庫鏈接地址</param>
/// <param name="obj">存儲參數對象</param>
/// <param name="dataTable">返回結果集</param>
/// <returns></returns>
public string GetStringAndDataTableByStorageName(string storageName, string DBUrl, object obj, out DataTable dataTable)
{
// 获取与数据库的连接对象並且绑定连接字符串
SqlConnection conn = new SqlConnection(DBUrl);
conn.Open();//打開資源
//获取数据库操作对象
SqlCommand cmd = conn.CreateCommand();
try
{
cmd.CommandText = storageName;//存儲名稱
cmd.CommandType = CommandType.StoredProcedure;
PropertyInfo[] properties = obj.GetType().GetProperties(BindingFlags.Instance | BindingFlags.Public);//獲取object中的字段名和值
for (int i = 0; i < properties.Length; i++)
{
if (i == (properties.Length - 1))
{//設定輸出的類型和值
cmd.Parameters.Add(properties[i].Name, SqlDbType.NVarChar, short.MaxValue).Direction = ParameterDirection.Output;
cmd.Parameters[properties[i].Name].Value = DBNull.Value;//賦值
}
else
{//設定輸入的類型和值
cmd.Parameters.Add(properties[i].Name, GetOracleDbType(properties[i], obj)).Direction = ParameterDirection.Input;
cmd.Parameters[properties[i].Name].Value = properties[i].GetValue(obj, null);//賦值
}
}
DataTable dt = new DataTable();
SqlDataAdapter oda = new SqlDataAdapter(cmd);
oda.Fill(dt);
dt.TableName = "數據集";
dataTable = dt;//返回數據結果集
string message = cmd.Parameters[properties[properties.Length - 1].Name].Value.ToString();//獲取輸出的字符串
cmd.Dispose();//釋放資源
conn.Dispose();//釋放資源
conn.Close();//關閉
return message;
}
catch (Exception ex)
{
cmd.Dispose();//釋放資源
conn.Dispose();//釋放資源
conn.Close();//關閉
throw ex;
}
}
/// <summary>
/// 將輸入參數的類型與SQLServer中的參數類型轉化一致
/// </summary>
/// <param name="propertyInfo">屬性特征</param>
/// <param name="obj">對象</param>
/// <returns></returns>
private SqlDbType GetOracleDbType(PropertyInfo propertyInfo, object obj)
{
try
{
SqlDbType sqlDbType = new SqlDbType();
switch (propertyInfo.GetValue(obj, null).GetType().Name)
{
case "String":
sqlDbType = SqlDbType.NVarChar;
break;
case "Int16":
sqlDbType = SqlDbType.SmallInt;
break;
case "Int32":
sqlDbType = SqlDbType.Int;
break;
case "Int64":
sqlDbType = SqlDbType.BigInt;
break;
case "DateTime":
sqlDbType = SqlDbType.DateTime;
break;
case "Boolean":
sqlDbType = SqlDbType.Bit;
break;
case "Byte":
sqlDbType = SqlDbType.TinyInt;
break;
case "Decimal":
sqlDbType = SqlDbType.Decimal;
break;
}
return sqlDbType;
}
catch (Exception ex)
{
throw ex;
}
}
/// <summary>
        /// 以現有表格數據批量添加數據
        /// </summary>
        /// <param name="dt">數據表格</param>
/// <param name="FormName">數據表名</param>
        /// <param name="DBUrl">數據庫鏈接地址</param>
        /// <returns></returns>
public bool AddInBatchesToDataTable(DataTable dt,string FormName, string DBUrl )
{
try
{
if (FormName.ToString().Trim() == "") throw new Exception("數據表名不能为空");
System.Diagnostics.Debug.WriteLine("----------------------開始執行--------------------------");
System.Diagnostics.Debug.WriteLine("執行表明:" + dt.TableName + "--------------------------");
long star = Convert.ToInt64(System.DateTime.Now.ToString("yyyyMMddHHmmssfff"));
SqlConnection conn = new SqlConnection(DBUrl);
SqlBulkCopy bulkCopy = new SqlBulkCopy(DBUrl, SqlBulkCopyOptions.UseInternalTransaction);
bulkCopy.BatchSize = 100000;
bulkCopy.BulkCopyTimeout = 260;
bulkCopy.DestinationTableName = FormName; //服务器上目标表的名称
bulkCopy.BatchSize = dt.Rows.Count; //每一批次中的行数
try
{
conn.Open();
if (dt != null && dt.Rows.Count != 0)
bulkCopy.WriteToServer(dt); //将提供的数据源中的所有行复制到目标表中
}
catch (Exception ex)
{
throw ex;
}
finally
{
conn.Close();
if (bulkCopy != null)
bulkCopy.Close();
}
long end = Convert.ToInt64(System.DateTime.Now.ToString("yyyyMMddHHmmssfff"));
System.Diagnostics.Debug.WriteLine("共添加:" + dt.Rows.Count + "條數數據----耗時:" + ((end - star) / 10000) + "." + ((end - star) % 10000) + "秒");
System.Diagnostics.Debug.WriteLine("----------------------執行結束--------------------------");
return true;
}
catch (Exception ex)
{
throw ex;
}
}
}

  

基于SqlClient开发SQLServer工具类 伸手党的福音的更多相关文章

  1. 基于ManagedDataAccess开发的OracleDBHelpe工具集伸手党的福音

    在使用前先加入ManagedDataAccessDLL文件方可使用 添加方法:右键项目.点击管理NuGet程序包,点击浏览,在输入框内输入ManagedDataAccess,再点击安装即可 Oracl ...

  2. DbUtils是Apache出品一款简化JDBC开发的工具类

    DbUtils     - DbUtils是Apache出品一款简化JDBC开发的工具类     - 使用DbUtils可以让我们JDBC的开发更加简单     - DbUtils的使用:       ...

  3. 用Java开发一个工具类,提供似于js中eval函数功能的eval方法

    今天在看到<Java疯狂讲义>中一个章节习题: 开发一个工具类,该工具类提供一个eval()方法,实现JavaScript中eval()函数的功能--可以动态运行一行或多行程序代码.例如: ...

  4. iOS开发——基于corelocation位置定位——工具类

    (代码工具类已写好,空闲时间整理成文档,待更新……)

  5. Android开发常用工具类

    来源于http://www.open-open.com/lib/view/open1416535785398.html 主要介绍总结的Android开发中常用的工具类,大部分同样适用于Java. 目前 ...

  6. IOS开发--常用工具类收集整理(Objective-C)(持续更新)

    前言:整理和收集了IOS项目开发常用的工具类,最后也给出了源码下载链接. 这些可复用的工具,一定会给你实际项目开发工作锦上添花,会给你带来大大的工作效率. 重复造轮子的事情,除却自我多练习编码之外,就 ...

  7. android 开发 常用工具类

    转载请标明出处:http://blog.csdn.net/lmj623565791/article/details/38965311,本文出自[张鸿洋的博客] 打开大家手上的项目,基本都会有一大批的辅 ...

  8. Java 连接 SqlServer工具类

    1.下载 server2008R2驱动jar包 下载jar包 http://www.microsoft.com/zh-cn/download/confirmation.aspx?id=21599 2. ...

  9. 最全Android开发常用工具类

    主要介绍总结的Android开发中常用的工具类,大部分同样适用于Java. 目前包括  HttpUtils.DownloadManagerPro.Safe.ijiami.ShellUtils.Pack ...

随机推荐

  1. go-面向对象编程(下)

    面向对象编程思想-抽象 抽象的介绍 我们在前面去定义一个结构体时候,实际上就是把一类事物的共有的 属性( 字段)和 行为( 方法)提取 出来,形成一个 物理模型(结构体).这种研究问题的方法称为抽象 ...

  2. Vue介绍以及模板语法-插值

    1.Vue的介绍 Vue是一套用于构建用户界面的渐进式框架. 注意:Vue是一个框架,相对于jq库来说,是由本质的区别的:https://cn.vuejs.org/ Vue不支持IE8及一下版本,因为 ...

  3. CAD制图初学入门教程:怎么在CAD中绘制箭头

    在接触CAD的时候大家有没有和小编一样感觉无所适从,所以下面就来和大家分享一个CAD制图初学入门教程,在CAD中绘制箭头.在CAD图形上进行标注内容的时候一般都会使用箭头来进行指示,那具体怎么在CAD ...

  4. AppBoxFuture(八): 另类的ORM实现

      通常的ORM实现基于配置或注释,由反射或Emit生成相应的Sql语句,然后将Sql发送给数据库解析Sql字符串生成AST再交给优化器处理后执行,返回的数据再经由反射或Emit转换为相应的实体实例. ...

  5. sql使用cte表达式进行递归查询

    --递归获取所有子节点 with temp as ( select * from MK_Base_Department where F_DepartmentId='5f258320-c1b7-42a4 ...

  6. ABP进阶教程2 - 组合查询

    点这里进入ABP进阶教程目录 更新数据传输对象 打开应用层(即JD.CRS.Application)的Course\Dto\GetAllCoursesInput.cs //Course数据传输对象(查 ...

  7. 记录C#-WPF布局面板

    StackPanel:适合水平或者垂直方向的布局 DockPanel:区域布局 WrapPanel:自动换行的StackPanel布局 Grid:网格布局

  8. Vue.js+cube-ui(Scroll组件)实现类似头条效果的横向滚动导航条

    本博主在一次个人移动端项目中,遇到这么一个需求:希望自己的项目中,头部导航条的效果可以像今日头条那样,横向滚动! 对于这样的效果,在各大移动端项目中几乎是随处可见,为什么呢? 我们都知道,对于移动端也 ...

  9. MSSQL添加外键

    alter table 需要建立外键的表 with check/nocheck add constraint 外键名字 foreign key (需要建立外键的字段名) references 外键表( ...

  10. bay——安装_RAC11g_LC_测试环境-rehat6+udev.txt

    ★★★____★☆★〓〓〓〓→VMware vSphere Client6.0 https://10.20.4.200/ 下载Vwmare IP:10.20.4.200-------账号:root-- ...