封装几个操作数据库的方法SqlHelper
来源:互联网 发布:union软件安卓 编辑:程序博客网 时间:2024/04/27 13:13
将常用的方法ExecuteNonQuary、ExecuteScalar、ExecuteReader和ExecuteAdapter的使用封装成方法,具如下
- 首先在App.config的xml文件里写上要连接的字符串,比如: <connectionStrings> <add connectionString="Data source=Graph;Initial catalog=中国省市;Integrated Security=true" name="PC" /> </connectionStrings>。
- 然后开始封装各个方法。新建一个cs文件,命名SqlHelper。首先获取连接字符串readonly static string constr = ConfigurationManager.ConnectionStrings["PC"].ConnectionString;因为这个连接字符串只在本文件中使用,所以可以加修饰符readonly
- 封装ExecuteNonQuary:方法要封装成静态方法。代码附在后面,这里要说的是,需要对其传一个可变参数params SqlParameter[]。方法中一定要对其判断,因为这个参数的空值和null是不一样的,所以一定要判断是否为null。
- 封装ExecuteScalar:大体上和ExecuteNonQuary一样
- 封装ExecuteReader:因为这个方法涉及到连接池的问题。所以和以上的两种方法有一定的差别,放一段代码。在这里创建连接对象的时候不能using起来,using被翻译成try { }finally { },在返回cmd.ExecuteReader的时候不能把连接关了,所以不能将SqlConnection conn = new SqlConnection(constr);给using起来。如果部using起来,那每次调用这个方法都会有一个对象放在连接池里面,所以可以在返回的cmd.ExecuteReader里面写上一个重载cmd.ExecuteReader(System.Data.CommandBehavior.CloseConnection);这样在返回的后关闭reader的同时将conn这个连接对象给关闭。由于创建连接对象的时候没有using起来,所以在返回的时候可能报异常,因此要将打开连接和返回这两条语句给try起来。
public static SqlDataReader ExecuteReader(string sql, params SqlParameter[] pms) { SqlConnection conn = new SqlConnection(constr); using (SqlCommand cmd = new SqlCommand(sql, conn)) { if (pms != null) { cmd.Parameters.AddRange(pms);//如果有其他的参数 就添加进去 } try { conn.Open(); return cmd.ExecuteReader(System.Data.CommandBehavior.CloseConnection);//调用完关闭reader的时候,把连接对象也关掉 } catch { conn.Close(); conn.Dispose(); throw; } } }
- 最后加一个ExecuteAdapter的方法。返回的类是DataTable的类型。思路和上面的一样。
- 代码如下
using System;using System.Collections.Generic;using System.Configuration;using System.Data.SqlClient;using System.Linq;using System.Text;using System.Threading.Tasks;using 用treeview实现省市联动;namespace SqlHelper的封装{ public static class SqlHelper { //1实现增删改ExecuteNonQuary //ConfigurationManager readonly static string constr = ConfigurationManager.ConnectionStrings["PC"].ConnectionString; public static int ExecuteNonQuary(string sql, params SqlParameter[] pms) { using (SqlConnection conn = new SqlConnection(constr)) { using (SqlCommand cmd = new SqlCommand(sql, conn)) { if (pms != null) { cmd.Parameters.AddRange(pms); } conn.Open(); return cmd.ExecuteNonQuery(); } } } //2实现查询,返回一个结果ExecuteScalar public static object ExecuteScalar(string sql, params SqlParameter[] pms) { using (SqlConnection conn = new SqlConnection(constr)) { using (SqlCommand cmd = new SqlCommand(sql, conn)) { if (pms != null) { cmd.Parameters.AddRange(pms); } conn.Open(); return cmd.ExecuteScalar(); } } } //3实现查询返回多条记录ExecuteReader public static SqlDataReader ExecuteReader(string sql, params SqlParameter[] pms) { SqlConnection conn = new SqlConnection(constr); using (SqlCommand cmd = new SqlCommand(sql, conn)) { if (pms != null) { cmd.Parameters.AddRange(pms);//如果有其他的参数 就添加进去 } try { conn.Open(); return cmd.ExecuteReader(System.Data.CommandBehavior.CloseConnection);//调用完关闭reader的时候,把连接对象也关掉 } catch { conn.Close(); conn.Dispose(); throw; } } } //4 添加方法ExecuteDataTable public static DataTable ExecuteDataTable(string sql, params SqlParameter[] pms) { DataTable dt = new DataTable(); using (SqlDataAdapter adapter = new SqlDataAdapter(sql, constr)) { if (pms != null) { adapter.SelectCommand.Parameters.AddRange(pms);//添加参数的方式 } adapter.Fill(dt); } return dt; } }}
0 0
- 封装几个操作数据库的方法SqlHelper
- 数据操作的封装--sqlhelper
- JDBC的简单封装,实现简单数据库操作工具类SQLHelper.
- SqlHelper工具类封装了对数据库的增删改查操作
- ado.net操作数据库基本函数,封装成SqlHelper类
- 数据库操作的几个方法的区别
- 谷歌封装操作数据库的方法
- ADO.NET操作封装(SqlHelper)
- SqlHelper数据库操作类
- 数据库操作类SQLHelper
- SqlHelper 数据库操作工具
- java连接oracle数据库,自己封装的几个方法
- 用到BMOB数据库和登录,自己封装的几个方法
- SQLHelper之简单方法封装
- ASP.NET中的数据库操作类sqlhelper及方法使用指南
- 数据库操作的封装
- 数据库操作的封装
- sqlHelper封装类,用于对数据库的操作,此类将查询操作中返回的结果集传递给了一个数组,直接将资源关闭
- which命令
- PhotoView点击放大图片效果
- MVC、MVP、MVVM的区别
- 让任意view具有滑动效果的SlideUp
- windows虚拟域名设置
- 封装几个操作数据库的方法SqlHelper
- 一个比较强大的提供各种形状的ImageView
- 再谈缓存穿透、缓存并发、热点缓存之最佳招式
- 仿淘宝京东拖拽商品详情页上下滚动黏滞效果
- oracle使用substr instr实现类似于java substring的功能
- gym 101196E Red Rover(枚举)
- 对视图的对角线切割DiagonalView
- Oralce 函数
- 浅谈快速排序