改进的sqlhelper学习日志
下面就是详细的sqlhelper的代码了
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data.SqlClient;
using System.Configuration;
using System.Data; namespace hr_DAL
{
public class SqlHelper
{
//连接对象和命令对象
private static SqlConnection conn;
private static SqlCommand cmd;
private static string constr = ConfigurationManager.ConnectionStrings["constr"].ConnectionString;
/// <summary>
/// 构造函数,实例化一个空的SqlHelper对象
/// </summary>
public SqlHelper()
{
}
#region 共有方法
/// <summary>
///方法:实例化连接对象
/// </summary>
private static void con()
{
conn = new SqlConnection(constr);
}
/// <summary>
/// 方法:打开连接,实例化命令对象
/// </summary>
/// <param name="sql"></param>
/// <returns></returns>
private static SqlCommand ExtCommand(string sql)
{
con();
//创建一个connection对象打开时,
//就会创建一个连接池,连接池和连接字符串完全匹配.
//如果一个连接对象的连接字符串和连接池完全匹配,就会把该连接对象放到匹配的池中,
//如果不完全匹配,则再创建一个连接池
conn.Open(); cmd = conn.CreateCommand();//将连接给命令对象
cmd.CommandText = sql;
return cmd; }
/// <summary>
/// 方法:关闭连接,释放资源
/// </summary>
private static void CloseConn()
{
if(conn!=null)//连接池是否为null,是否占用连接
{
if (conn.State == ConnectionState.Open)
{
conn.Close();//关闭了连接,
cmd.Dispose();//清空了连接字符串,即连接池
conn.Dispose();
}
} }
#endregion
/// <summary>
/// 方法:得到执行结果的首行首列
/// </summary>
/// <param name="sql"></param>
/// <returns></returns>
public static string GetOne(string sql)
{
ExtCommand(sql);
string result= (string) cmd.ExecuteScalar();
CloseConn();
return result;
} /// <summary>
/// 方法:用SqlDataAdapter得到一个表
/// </summary>
/// <param name="sql"></param>
/// <returns></returns>
public static DataTable GetTable(string sql)
{
ExtCommand(sql);
SqlDataAdapter sda = new SqlDataAdapter();
//将cmd命令对象交给适配器对象
sda.SelectCommand = ExtCommand(sql);
DataSet ds = new DataSet();
sda.Fill(ds,"table");
CloseConn();
return ds.Tables["table"]; #region SqlDataAdapter的使用方法
//SqlConnection conn = new SqlConnection(constr);
//SqlCommand cmd = new SqlCommand("select * from product", conn); //SqlDataAdapter sdat = new SqlDataAdapter(cmd);
//DataSet ds = new DataSet(); //sdat.Fill(ds, "p");
//dataGridView1.DataSource = ds.Tables["p"];
#endregion }/// <summary>
/// 方法:根据条件返回一个数据流
/// </summary>
/// <param name="sql"></param>
/// <returns></returns>
public static SqlDataReader GetReader(string sql)
{
ExtCommand(sql);
//CommandBehavior.CloseConnection表示数据流关闭,连接也关闭
SqlDataReader sdr = cmd.ExecuteReader(CommandBehavior.CloseConnection);
return sdr; }
}
}
改进的sqlhelper学习日志的更多相关文章
- GRE学习日志
发现开博客园真的很有督促作用,今天也顺便开个GRE学习日志吧 2015-02-09:单词 2015-02-10:单词 2015-02-11:单词 2015-03-02:阅读 2015-03-04:阅读 ...
- Cortex-M3学习日志(六) -- ADC实验
上一次简单的总结了一下DAC方面的知识,好吧,这次再来总结一下ADC方面的东东.ADC即Analog-to-Digital Converter的缩写,指模/数转换器或者模拟/数字转换器.现实世界是由模 ...
- Cortex-M3学习日志(五) -- DAC实验
终于逮了个忙里偷闲的机会,就再学一下LPC1768的外围功能吧,循序渐进是学习的基本规则,也许LPC1768的DAC与8位单片机16位单片机里面集成的DAC操作类似,但是既然这是懒猫的学习日志,就顺便 ...
- webpack2学习日志
webpack说容易也容易,说难也难,主要还是看个人,想学到什么样的程度,很多公司可能要求仅仅是会用就行,但是也有一些公司要求比较高,要懂一些底层的原理,所以还是要花一些时间的,看个人需求.这篇仅仅是 ...
- javascript学习日志:前言
javascript学习日志系列的所有博客,主要理论依据是<javascript权威指南>(犀牛书第6版)以及<javascript高级程序设计第三版>(红色书),目前js行业 ...
- MobileForm控件的使用方式-用.NET(C#)开发APP的学习日志
今天继续Smobiler开发APP的学习日志,这次是做一个title.toolbar.侧边栏三种效果 样式一 一. Toolbar 1. 目标样式 我们要实现上图中的效果 ...
- 我的游戏学习日志3——三国志GBA
我的游戏学习日志3——三国志GBA 三国志GBA由日本光荣公司1991~1995所推出<三国志>系列游戏,该作是光荣在GBA上推出的<三国志>系列作品的第一款.本游戏登场武将总 ...
- 【转】Cocos2d-x 3.1.1 学习日志6--30分钟了解C++11新特性
[转]Cocos2d-x 3.1.1 学习日志6--30分钟了解C++11新特性 Cocos2d-x 3.1.1 学习日志6--30分钟了解C++11新特性
- composer的安装和使用 学习日志
如果你做为一个phper,没有用过composer,那你真的不是一个合格的开发者.那么就来记录一下composer的学习日志 下面分享几个学习源头: composer中文网站:https://www. ...
随机推荐
- DEDE自带的采集功能,标题太短的解决方法
DEDE自带的采集功能,标题太短获取不全的解决方法搜索了好多之后,终于还是在dede的官方论坛找到了答案.增加采集标题长度:255 目的:原标题长度太小,影响文件采集⑴修改系统参数设置(文档标题最大 ...
- 原生Javascript实现控制DIV属性
写在前面: 从事前端工作已有一年之久,因为工作的性质,不太涉及JS方面,所以自己的JS水平一直处于小白阶段,工作闲暇之余,在网上找了一些小项目,希望练练手,促进自己成长.这是第一篇,后续还会有很多记录 ...
- web页面的优化
众所周知,一个web页面通常会包括HTML(XHTML.XML).CSS.Javascript,而其中HTML(XHTML.XML)为结构化语言,用于构建页面结构和相关数据:CSS则负责页面的样式,即 ...
- Fibonacci 数列递归 重复计算
public class Fibonacci{ public static long F(long n){ System.out.println("call F" + n); ) ...
- leetcode中一些要用到动态规划的题目
需要仔细回顾的题目: 1.Interleaving String 交叉存取字符串 2.Decode Ways 字符串解码 3.Subsets Subsets II 求一个 ...
- 24种设计模式--门面模式【Facade Pattern】
大家都写过纸质的信件吧,比如给女朋友写情书什么的,写信的过程大家都还记得吧,先写信的内容,然后写信封,把信放到信封中,封好,投递到信箱中进行邮递,这个过程还是比较简单的,虽然简单,这四个步骤都是要跑的 ...
- php5.4安装ecshopphp5.4问题及解决
includes/cls_template.php line422 将 $tag_sel = array_shift(explode(" ", $tag)); 这句话拆开为两句. $tag_exp = ...
- python 简单谈谈“类”
文章出处:http://www.cnblogs.com/winstic/,请保留此连接 面向对象是python语言的一大特色,而类又是面向对象编程的核心 先来一段关于类的声明: class myCla ...
- C#中获得汉字的首拼音(简化版)
利用汉字在计算机里面的编码来得到汉字的首拼音: static public string GetChineseSpell(string strText) { int len = strText.Len ...
- 关于如何设置reduce的个数
在默认情况下,一个MapReduce Job如果不设置Reducer的个数,那么Reducer的个数为1.具体,可以通过JobConf.setNumReduceTasks(int numOfReduc ...