简单,实用,留存。

 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 CarHailing.Base
{
/// <summary>
/// 数据库帮助类
/// </summary>
public class SqlHelp
{
/// <summary>
/// 创建一个已打开的连接
/// </summary>
/// <returns></returns>
private static SqlConnection CreateConn()
{
SqlConnection conn = new SqlConnection(ConfigurationManager.ConnectionStrings["conn"].ConnectionString);
conn.Open();
return conn;
} /// <summary>
/// 执行sql语句,返回受影响的行数
/// </summary>
/// <param name="sql"></param>
/// <returns></returns>
public static int ExecuteNonQuery(string sql)
{
return ExecuteNonQuery(sql, null);
} /// <summary>
/// 执行sql语句,返回受影响的行数
/// </summary>
/// <param name="sql"></param>
/// <returns></returns>
public static int ExecuteNonQuery(string sql, SqlParameter[] ps)
{
SqlConnection conn = CreateConn();
SqlCommand cmd = new SqlCommand(sql, conn);
try
{
if (ps != null)
{
cmd.Parameters.AddRange(ps);
}
return cmd.ExecuteNonQuery();
}
catch (Exception ex)
{
return ;
}
finally
{
conn.Close();
}
} /// <summary>
/// 执行sql语句,返回一个结果表
/// </summary>
/// <param name="sql"></param>
/// <returns></returns>
public static DataTable ExecuteSelectDataTable(string sql)
{
return ExecuteSelectDataTable(sql, null);
} /// <summary>
/// 执行sql语句,返回一个结果表
/// </summary>
/// <param name="sql"></param>
/// <param name="ps"></param>
/// <returns></returns>
public static DataTable ExecuteSelectDataTable(string sql, SqlParameter[] ps = null)
{ SqlConnection conn = CreateConn();
SqlCommand cmd = new SqlCommand(sql, conn);
try
{
if (ps != null)
{
cmd.Parameters.AddRange(ps);
}
//SqlDataAdapter sda = new SqlDataAdapter(cmd);
SqlDataReader read = cmd.ExecuteReader();
DataTable table = new DataTable();
table.Load(read);
//DataSet ds = new DataSet();
//sda.Fill(ds);
return table;
}
finally
{
conn.Close();
}
} /// <summary>
///
/// </summary>
/// <param name="sql"></param>
/// <returns></returns>decimal
public static DataTable ExecuteSelectPageDataTable(string sql, ref SqlParameter[] ps)
{
SqlConnection conn = CreateConn();
SqlCommand cmd = new SqlCommand(sql, conn);
cmd.CommandType = CommandType.StoredProcedure;
try
{
cmd.Parameters.AddRange(ps);
SqlDataAdapter sda = new SqlDataAdapter(cmd);
DataSet ds = new DataSet();
sda.Fill(ds);
return ds.Tables[];
}
catch (SqlException ex)
{
throw ex;
}
finally
{
conn.Close();
}
} //public static SqlDataReader ExecuteReader(string cmdText, CommandType cmdType, params SqlParameter[] cmdParms)
//{
// SqlCommand cmd = new SqlCommand();
// SqlConnection conn = CreateConn(); // try
// {
// ProCommand(cmd, conn, cmdText, cmdType, cmdParms);
// SqlDataReader rdr = cmd.ExecuteReader(CommandBehavior.CloseConnection);
// //cmd.Parameters.Clear();//放到这里,返回参数会被清空。
// return rdr;
// }
// catch
// {
// conn.Close();
// throw;
// }
//} /// <summary>
/// 分页读取数据
/// </summary>
/// <param name="query">select查询语句</param>
/// <param name="pageSize">每页显示数据数</param>
/// <param name="PageIndex">当前页码</param>
/// <param name="dt">存储数据的DataTable实例</param>
public static void PageDataTable(string query, int pageSize, int PageIndex, DataTable dt)
{
//读取数据的开始索引
long startIndex = (PageIndex - ) * pageSize;
//读取数据的结束索引
long endIndex = PageIndex * pageSize - ;
//DataReader读取的当前数据行的索引
long readToIndex = -;
using (SqlConnection conn = CreateConn())
{
SqlCommand cmd = new SqlCommand(query, conn);
//conn.Open();
SqlDataReader dr = cmd.ExecuteReader();
//数据源中的列数
int cols = dr.VisibleFieldCount;
//构造DataTable结构
for (int i = ; i < cols; i++)
{
dt.Columns.Add(new DataColumn(dr.GetName(i), dr.GetFieldType(i)));
}
//读取数据,将数据一行一行添加到DataTable
while (dr.Read())
{
readToIndex++;
//当DataReader指针在开始索引和结束索引闭区间时才读取数据构造DataRow
//并添加到DataTable
if (readToIndex >= startIndex && readToIndex <= endIndex)
{
DataRow row = dt.NewRow();
for (int i = ; i < cols; i++)
{
row[i] = dr[i];
}
dt.Rows.Add(row);
}
}
dr.Close();
}
}
}
}

C#,一份超简单的数据库帮助类,SqlHelp的更多相关文章

  1. 通过一个简单的数据库操作类了解PHP链式操作的实现

    class Model{ public $table; //操作的表; private $opt; //查询的参数; private $pri; //表的主键; private $lastSql; / ...

  2. 超简单的php缓存类

    <?php class Cache { private $dir = "data/cache/";//定义缓存目录 private $key='c_a_sss'; // 文件 ...

  3. 开发C# .net时使用的数据库操作类SqlHelp.cs

    练习开发WPF程序的时候,是这样写的,虽然很简单,相必很多新手会用到,所以拿来共享一下, using System; using System.Collections.Generic; using S ...

  4. 简单的php Mysql类(查询 删除 更新)

    php Mysql类一般都包括了几乎我们常用的数据库操作方法,这里只提供了查询 删除 更新三种操作,算不是很全只是一个简单的数据库查询类了.      代码如下 复制代码 class mysql { ...

  5. 超简单使用批处理(batch)操作数据库

    超简单使用批处理(batch)操作数据库 批处理(batch)是什么 批处理的执行就好比快递员的工作: 未使用批处理的时候,快递员一次从分发点将一件快递发给客户: 使用批处理,则是快递员将所有要派送的 ...

  6. 超简单的CDH6部署和体验(单机版)

    欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...

  7. mysql主从复制(超简单)

      mysql主从复制(超简单) 怎么安装mysql数据库,这里不说了,只说它的主从复制,步骤如下: 1.主从服务器分别作以下操作:  1.1.版本一致  1.2.初始化表,并在后台启动mysql  ...

  8. ssh框架整合---- spring 4.0 + struts 2.3.16 + maven ss整合超简单实例

    一 . 需求 学了这么久的ssh,一直都是别人整合好的框架去写代码,自己实际动手时才发现框架配置真是很坑爹,一不小心就踏错,真是纸上得来终觉浅! 本文将记录整合struts + spring的过程 , ...

  9. 这些优化 Drupal 网站速度的超简单办法,你忽略了多少?

    “怎么样能让我的 Drupal 网站更快一些?”是我们最常遇到的一个问题.站点速度确实非常重要,因为它会影响你的 SEO排名效果.访客是否停留以及你自己管理网站所需要的时间. 今天我们就来看看那些通过 ...

随机推荐

  1. C# post数据时 出现如下错误: System.Net.WebException: 操作超时

    net(客户端)调用IIS(服务端)出现503后,就报操作超时错误 问题描述: 服务端环境: IIS 客户端环境: windowsxp + iis + .net 调用时出现如下错误: System.N ...

  2. 芝麻HTTP:Python爬虫入门之Urllib库的基本使用

    1.分分钟扒一个网页下来 怎样扒网页呢?其实就是根据URL来获取它的网页信息,虽然我们在浏览器中看到的是一幅幅优美的画面,但是其实是由浏览器解释才呈现出来的,实质它是一段HTML代码,加 JS.CSS ...

  3. php composer的学习之路(一)

    composer的介绍请看这里  http://docs.phpcomposer.com/00-intro.html composer的安装过程我就不介绍了,windows系统下跟其他安装没区别,一直 ...

  4. Kettle根据时间戳同步数据实现

    1 Kettle总体步骤 由于Kettle自身的特殊性以及在多个步骤中kettle自身处理数据库事务的特殊性,尝试了很多种方案,最终确定暂使用如下方案. 1.使用此方案可以解决kettle本身数据库事 ...

  5. Linux入门——开机启动过程浅析

    Linux开机启动过程浅析 Introduction 开机启动过程分为以下6个步骤,分别是BIOS, MBR, GRUB, Kernel, Init, RunLevel, RunDefinition ...

  6. Bzoj4555: [Tjoi2016&Heoi2016]求和

    题面 Bzoj Sol 推柿子 因为当\(j>i\)时\(S(i, j)=0\),所以有 \[\sum_{i=0}^{n}\sum_{j=0}^{n}S(i, j)2^j(j!)\] 枚举\(j ...

  7. BZOJ第7页养成计划

    嗯,用这篇博客当一个目录,方便自己和学弟(妹?)们查阅.不定期更新. BZOJ1600   BZOJ1601   BZOJ1602   BZOJ1603   BZOJ1604   BZOJ1605   ...

  8. ssm实现分页查询

    ssm整合实现分页查询 一.通过limit查询语句实现分页,并展示 1.mapper.xml配置 <select id="selectUsersByPage" paramet ...

  9. three.js引擎基础知识—摄像机、场景及渲染器

    一.three.js采用右手坐标系: x轴正方向向右,y轴正方向向上,z轴由屏幕从里向外,如下图右: 二.3D编程三要素:场景.渲染器.摄像机 1.场景:创建的物品和模型都需放入场景中 threejs ...

  10. About Windows 10 SDK Preview Build 17110

    在 Windows Developer Day 活动同时,微软正式 Release 了 Windows 10 SDK Preview Build 17110. Windows 10 SDK Previ ...