ADO.NET链接数据库封装方法
/// <summary>
/// 获取一个表
/// </summary>
/// <param name="sql"></param>
/// <param name="pars"></param>
/// <returns></returns>
public DataTable GetTable(string sql, params SqlParameter[] pars)
{
// using (var con = new SqlConnection(hisConstr))
using (var con = new SqlConnection(ConnectionString))
{
try
{
var cmd = new SqlCommand();
cmd.Connection = con;
cmd.CommandText = sql;
cmd.Parameters.AddRange(pars);
con.Open();
var dr = cmd.ExecuteReader();
var dt = new DataTable();
dt.Load(dr);
dr.Close();
return dt;
}
catch (Exception exc)
{
throw exc;
}
finally
{
con.Close();
}
}
}
/// <summary>
/// 查询数据返回list
/// </summary>
/// <param name="sql"></param>
/// <param name="pars"></param>
/// <returns></returns>
public List<Dictionary<string, dynamic>> GetList(string sql,params SqlParameter[] pars)
{
using (var con = new SqlConnection(ConnectionString))
{
var cmd =new SqlCommand();
cmd.Connection = con;
cmd.CommandText = sql;
cmd.Parameters.AddRange(pars);
con.Open();
var dr = cmd.ExecuteReader();
var list = new List<Dictionary<string,dynamic>>();
while (dr.Read())
{
var newdic = new Dictionary<string,dynamic>();
foreach (var item in Enumerable.Range(0,dr.FieldCount).ToDictionary(dr.GetName,dr.GetValue))
{
newdic.Add(item.Key,item.Value==DBNull.Value?"":item.Value);
}
list.Add(newdic);
}
return list;
}
}
/// <summary>
/// 查询数据,返回单个值
/// </summary>
/// <param name="sql">sql语句</param>
/// <param name="pars">参数</param>
/// <returns></returns>
public object GetValue(string sql, params SqlParameter[] pars)
{
using (var con = new SqlConnection(ConnectionString))
{
var cmd = new SqlCommand();
cmd.Connection = con;
cmd.CommandText = sql;
cmd.Parameters.AddRange(pars);
con.Open();
var value = cmd.ExecuteScalar();
return value;
}
}
/// <summary>
/// 增删改数据
/// </summary>
/// <param name="sql">sql语句</param>
/// <param name="pars">参数</param>
/// <returns></returns>
public int SavaData(string sql, params SqlParameter[] pars)
{
using (var con = new SqlConnection(ConnectionString))
{
var cmd = new SqlCommand();
cmd.Connection = con;
cmd.CommandText = sql;
cmd.Parameters.AddRange(pars);
con.Open();
return cmd.ExecuteNonQuery();
}
}
/// <summary>
/// 执行事务的SQL语句
/// </summary>
/// <param name="childSqls">SQL语句集合</param>
/// <param name="childParametersList">参数列表集合</param>
/// <returns></returns>
public bool ChageDataWithTransaction(List<string> sqls, List<List<SqlParameter>> parametersList)
{
using (var con = new SqlConnection(ConnectionString))
{
con.Open();
var tran = con.BeginTransaction();
try
{
var cmd = new SqlCommand();
cmd.Connection = con;
cmd.Transaction = tran;
for (int i = 0; i < sqls.Count; i++)
{
cmd.Parameters.Clear();
cmd.CommandText = sqls[i];
cmd.Parameters.AddRange(parametersList[i].ToArray());
cmd.ExecuteNonQuery();
}
tran.Commit();
return true;
}
catch (Exception exc)
{
tran.Rollback();
throw exc;
}
finally
{
con.Close();
}
}
}
ADO.NET链接数据库封装方法的更多相关文章
- Asp.Net Core 2.0 项目实战(4)ADO.NET操作数据库封装、 EF Core操作及实例
Asp.Net Core 2.0 项目实战(1) NCMVC开源下载了 Asp.Net Core 2.0 项目实战(2)NCMVC一个基于Net Core2.0搭建的角色权限管理开发框架 Asp.Ne ...
- ADO 动态链接数据库
ADO(ActiveX Data Objects)是基于组件的数据库编程接口,它是一个和编程语言无关的COM组件系统. 下面内容转载自:http://www.vckbase.com/document/ ...
- [Django框架 - 静态文件配置、request对象方法初识、 pycharm链接数据库、ORM实操增删改查、django请求生命周期]
[Django框架 - 静态文件配置.request对象方法初识. pycharm链接数据库.ORM实操增删改查.django请求生命周期] 我们将html文件默认都放在templates文件夹下 将 ...
- PHP 链接多种数据库 的方法
数据库中 单词之间的空格(一个语句前面和后面做字符串拼接的时候最好留空格 ) 可以随便加 其他地方 禁止随便加空格!!(加了 就报错)! =====================总结=== ...
- 使用Spring.net中对Ado.net的抽象封装来访问数据库
使用Spring.net中对Ado.net的抽象封装来访问数据库 Spring.NET是一个应用程序框架,其目的是协助开发人员创建企业级的.NET应用程序.它提供了很多方面的功能,比如依赖注入 ...
- Python 3.4 链接mysql5.7 数据库使用方法
最近笔者在研究Python3.4链接MySQL5.7版本,笔者意图在网上找到一个比较好的链接方式,网上介绍的大致有 mysqldb或者pymssql这两种方法来链接,mysqldb下载地址http:/ ...
- 封装JDBC操作数据库的方法
自己动手封装java操作数据库的方法: 一:目录结构 二:所需依赖的第三方jar包 这里只需引入mysql-connector-java-5.1.8-bin.jar,mysql数据库驱动jar包 三: ...
- 用ADO操作数据库的方法步骤(ZT)
http://www.cppblog.com/changshoumeng/articles/113437.html 学习ADO时总结的一些经验 用ADO操作数据库的方法步骤 ADO接口简介 ADO库包 ...
- 摘:用ADO操作数据库的方法步骤
用ADO操作数据库的方法步骤 ADO接口简介 ADO库包含三个基本接口:_ConnectionPtr接口._CommandPtr接口和_RecordsetPtr接口. _ConnectionPtr接口 ...
随机推荐
- Saiku免登录嵌入其他系统使用(十一)
Saiku免登录嵌入其他系统使用 Saiku可通过iframe嵌入其他系统使用,但是正常情况下都需要先登录系统,然后还需要登录saiku,最后才能访问saiku中的数据 下面来讲解一下如何使Saiku ...
- STL源码剖析01-allocator
#include <iostream> #include <new> #include <cstddef> #include <vector> usin ...
- python 图像转矩阵,矩阵转图像
1.图像转换为矩阵 matrix = numpy.asarray(image) Help on function asarray in module numpy.core.numeric: asarr ...
- python day28--json,pickle,hashlib,logging
一.json格式的限制 1.json格式的key必须是字符串数据类型,如果是数字dumps后会被转为字符串. # dic = {1:2,3:4} # str_dic = json.dumps(dic) ...
- Python学习笔记第二十七周(Bootstrap)
目录: 全局样式 一.栅格系统 二.表单 三.按钮 四.导航 五.按钮组 六.面板 七.表格 八.分页 九.排版 十.图片 十一.辅助类 十二.响应式工具 组件 内容: 前言: 首先通过https: ...
- SpringBoot配置SSL证书支持
Spring Boot配置ssl证书 一.申请SSL证书 在各大云服务商都可以申请到SSL官方证书. 我这里是在阿里云上申请的,申请后下载,解压.如图: 二.用JDK中keytool是一个证书管理工 ...
- this指向问题 --无return
this的指向在函数定义的时候是确定不了的只有在函数执行的时候才能确定this到底指向谁.this指向上一级对象 1.函数调用,this指向window var color = "red&q ...
- Docker跨主机link
user case:一个app container向一个oracle container跨主机传输数据. 思路一:将oracle对外暴露端口,将hostA的IP添加入app上/ect/hosts上.这 ...
- [Java] 資料輸入的差異性(System.in、BufferedReader、Scanner)
一.System.in System.in提供的read方法每次只能讀取一個字節的數據,不實用 二.BufferedReader BufferedReader類位於java.io包中,使用要加上 im ...
- linux环境下安装nginx步骤(不错)
开始前,请确认gcc g++开发类库是否装好,默认已经安装. ububtu平台编译环境可以使用以下指令 apt-get install build-essential apt-get install ...