DbHelperSQL
1 using System; 2 using System.Collections.Generic; 3 using System.Text; 4 using System.Data; 5 using System.Data.SqlClient; 6 using System.Reflection;//反射命名空间 7 8 namespace LeaveWordBorad.DAL 9 { 10 /// <summary> 11 /// 数据层 - 数据库 操作类 12 /// </summary> 13 internal class DbHelperSQL 14 { 15 //获得配置文件的连接字符串 16 public static string strConn = System.Configuration.ConfigurationManager.ConnectionStrings["connStr"].ConnectionString; 17 18 #region 01.查询数据表 +static DataTable GetTabel(string strSql, params SqlParameter[] paras) 19 /// <summary> 20 /// 查询数据表 21 /// </summary> 22 /// <param name="strSql">sql语句</param> 23 /// <param name="paras">参数数组</param> 24 /// <returns></returns> 25 public static DataTable GetDataTable(string strSql, params SqlParameter[] paras) 26 { 27 DataTable dt = null; 28 using (SqlConnection conn = new SqlConnection(strConn)) 29 { 30 //创建 适配器对象(sql命令,连接通道) 31 SqlDataAdapter da = new SqlDataAdapter(strSql, conn); 32 //添加参数 33 da.SelectCommand.Parameters.AddRange(paras); 34 //创建数据表对象 35 dt = new DataTable(); 36 //适配器 读取数据库,并将查询的结果 装入程序的 dt里 37 da.Fill(dt); 38 } 39 return dt; 40 } 41 #endregion 42 43 #region 02.执行 增删改 (非查询语句) +int ExcuteNonQuery(string strSql, params SqlParameter[] paras) 44 /// <summary> 45 /// 执行 增删改 (非查询语句) 46 /// </summary> 47 /// <param name="strSql"></param> 48 /// <param name="paras"></param> 49 /// <returns></returns> 50 public static int ExcuteNonQuery(string strSql, params SqlParameter[] paras) 51 { 52 int res = -1; 53 //创建连接通道 54 using (SqlConnection conn = new SqlConnection(strConn)) 55 { 56 //创建命令对象(sql语句,连接通道) 57 SqlCommand cmd = new SqlCommand(strSql, conn); 58 //添加参数 59 cmd.Parameters.AddRange(paras); 60 conn.Open(); 61 res = cmd.ExecuteNonQuery(); 62 } 63 return res; 64 } 65 #endregion 66 67 #region 02a.执行 多条增删改 (非查询语句) +int ExcuteNonQuery(string strSql, params SqlParameter[] paras) 68 /// <summary> 69 /// 执行 多条增删改 (非查询语句) 70 /// </summary> 71 /// <param name="strSql"></param> 72 /// <param name="paras"></param> 73 /// <returns></returns> 74 public static int ExcuteNonQuerys(string[] strSqls, SqlParameter[][] paras2Arr) 75 { 76 int res = 0; 77 //创建连接通道 78 using (SqlConnection conn = new SqlConnection(strConn)) 79 { 80 conn.Open(); 81 //创建 事务 82 SqlTransaction tran = conn.BeginTransaction(); 83 //创建命令对象 84 SqlCommand cmd = new SqlCommand(); 85 //为命令对象指定连接通道 86 cmd.Connection = conn; 87 //为命令对象指定事务 88 cmd.Transaction = tran; 89 try 90 { 91 //循环执行sql语句 92 for (int i = 0; i < strSqls.Length; i++) 93 { 94 //获得要执行的sql语句 95 string strSql = strSqls[i]; 96 //为命令对象指定 此次执行的 sql语句 97 cmd.CommandText = strSql; 98 //添加参数 99 if (paras2Arr.Length > i)//如果 参数2维数组的长度大于当前循环的下标 100 { 101 cmd.Parameters.AddRange(paras2Arr[i]);//将 交错数组 的第一个元素(其实也是一个数组,添加到参数集合中) 102 } 103 res += cmd.ExecuteNonQuery(); 104 cmd.Parameters.Clear(); 105 } 106 tran.Commit();//提交事务 107 } 108 catch (Exception ex) 109 { 110 res = 0; 111 tran.Rollback();//回滚事务 112 throw ex; 113 } 114 } 115 return res; 116 } 117 #endregion 118 119 #region 02.执行 查询单个值 +int ExcuteScalar(string strSql, params SqlParameter[] paras) 120 /// <summary> 121 /// 执行 增删改 (非查询语句) 122 /// </summary> 123 /// <param name="strSql"></param> 124 /// <param name="paras"></param> 125 /// <returns></returns> 126 public static int ExcuteScalar(string strSql, params SqlParameter[] paras) 127 { 128 int res = -1; 129 //创建连接通道 130 using (SqlConnection conn = new SqlConnection(strConn)) 131 { 132 //创建命令对象(sql语句,连接通道) 133 SqlCommand cmd = new SqlCommand(strSql, conn); 134 //添加参数 135 cmd.Parameters.AddRange(paras); 136 conn.Open(); 137 res = Convert.ToInt32(cmd.ExecuteScalar()); 138 } 139 return res; 140 } 141 #endregion 142 143 #region 04.执行 特殊的 分页存储过程 +DataTable GetPageListByProc(int pageIndex, int pageSize,out int pageCount,out int rowCount) 144 /// <summary> 145 ///04.执行 特殊的 分页存储过程 146 /// </summary> 147 /// <param name="proName">存储过程名称</param> 148 /// <param name="pageIndex">页码</param> 149 /// <param name="pageSize">页容量</param> 150 /// <param name="pageCount">总页数--输出</param> 151 /// <param name="rowCount">总行数--输出</param> 152 /// <returns></returns> 153 public static DataTable GetPageListByProc(string proName,int pageIndex, int pageSize,bool isDel, out int pageCount, out int rowCount) 154 { 155 DataTable dt = new DataTable(); 156 //创建连接通道 157 using (SqlConnection conn = new SqlConnection(strConn)) 158 { 159 //创建适配器对象 160 SqlDataAdapter da = new SqlDataAdapter(proName, conn); 161 //设置 命令类型 为存储过程 162 da.SelectCommand.CommandType = CommandType.StoredProcedure; 163 //设置 参数 164 da.SelectCommand.Parameters.AddWithValue("@pageIndex", pageIndex);//当前页码 165 da.SelectCommand.Parameters.AddWithValue("@pageSize", pageSize);//页容量 166 da.SelectCommand.Parameters.AddWithValue("@isDel", isDel);//页容量 167 168 //在存储过程中 输出参数 169 da.SelectCommand.Parameters.Add(new SqlParameter("@pageCount", SqlDbType.Int));//总页数 170 da.SelectCommand.Parameters.Add(new SqlParameter("@rowCount", SqlDbType.Int));//总行数 171 //将后面两个参数 设置为 输出类型 172 da.SelectCommand.Parameters[3].Direction = ParameterDirection.Output; 173 da.SelectCommand.Parameters[4].Direction = ParameterDirection.Output; 174 175 //执行 并将查询到的 结果 赋给 数据表对象 176 da.Fill(dt); 177 //获得 存储过程 返回的 输出参数 178 pageCount = Convert.ToInt32(da.SelectCommand.Parameters[3].Value); 179 rowCount = Convert.ToInt32(da.SelectCommand.Parameters[4].Value); 180 } 181 //返回数据表 182 return dt; 183 } 184 #endregion 185 186 #region 04.执行 特殊的 分页存储过程 +DataTable GetPageListByProc(int pageIndex, int pageSize,out int pageCount,out int rowCount) 187 /// <summary> 188 ///04.执行 特殊的 分页存储过程 189 /// </summary> 190 /// <param name="proName">存储过程名称</param> 191 /// <param name="pageIndex">页码</param> 192 /// <param name="pageSize">页容量</param> 193 /// <param name="userId">用户id</param> 194 /// <param name="pageCount">总页数--输出</param> 195 /// <param name="rowCount">总行数--输出</param> 196 /// <returns></returns> 197 public static int ExcuteNonQueryWithProc(string proName, params SqlParameter[] paras) 198 { 199 DataTable dt = new DataTable(); 200 //创建连接通道 201 using (SqlConnection conn = new SqlConnection(strConn)) 202 { 203 SqlCommand cmd = new SqlCommand(proName,conn); 204 cmd.CommandType = CommandType.StoredProcedure; 205 cmd.Parameters.AddRange(paras); 206 conn.Open(); 207 return cmd.ExecuteNonQuery(); 208 } 209 } 210 #endregion 211 212 #region 01.3为 对象数据源控件 提供 分页数据 213 /// <summary> 214 /// 01.3为 对象数据源控件 提供 分页数据 215 /// </summary> 216 /// <param name="pageSize">页容量</param> 217 /// <param name="startRowIndex">起始行下标</param> 218 /// <returns></returns> 219 public static DataTable GetPagedListForObjectDataSource(int pageSize, int startRowIndex) 220 { 221 string strSql = "select * from(select Row_Number() over(order by cid) as num, * from Classes)as temp where num>@startRowIndex and num<=@size"; 222 SqlParameter[] paras = { 223 new SqlParameter("@startRowIndex",startRowIndex), 224 new SqlParameter("@size",pageSize+startRowIndex) 225 }; 226 return GetDataTable(strSql, paras); 227 } 228 #endregion 229 230 #region 3.执行查询多行语句 - 返回数据读取器 +static SqlDataReader ExcuteDataReader(string strSelectCmd, params SqlParameter[] paras) 231 /// <summary> 232 /// 执行查询多行语句 - 返回数据读取器 233 /// </summary> 234 /// <param name="strSelectCmd"></param> 235 /// <param name="paras"></param> 236 /// <returns></returns> 237 public static SqlDataReader ExcuteDataReader(string strSelectCmd, params SqlParameter[] paras) 238 { 239 SqlConnection conn = null; 240 try 241 { 242 //1.创建连接通道 243 conn = new SqlConnection(strConn); 244 //2.创建命令对象 245 SqlCommand cmd = new SqlCommand(strSelectCmd, conn); 246 //3.添加命令参数 247 cmd.Parameters.AddRange(paras); 248 //4.打开连接 249 conn.Open(); 250 //5.创建读取器(当关闭此读取器时,会自动关闭连接通道) 251 SqlDataReader dr = cmd.ExecuteReader(CommandBehavior.CloseConnection);//当关闭此读取器时,会自动关闭连接通道 252 //6.返回读取器 253 return dr; 254 } 255 catch (Exception ex) 256 { 257 conn.Dispose(); 258 throw ex; 259 } 260 } 261 #endregion 262 263 #region 2.0升级泛型版 ------ 执行查询多行语句 - 返回数据表 264 /// <summary> 265 /// 2.0升级泛型版 ------ 执行查询多行语句 - 返回数据表 266 /// </summary> 267 /// <typeparam name="T2">泛型类型</typeparam> 268 /// <param name="strSelectCmd">查询sql语句</param> 269 /// <param name="paras">查询参数</param> 270 /// <returns>泛型集合</returns> 271 public static List<T2> ExcuteList<T2>(string strSelectCmd, params SqlParameter[] paras) 272 { 273 //1.创建连接通道 274 using (SqlConnection conn = new SqlConnection(strConn)) 275 { 276 //2.创建适配器 277 SqlDataAdapter da = new SqlDataAdapter(strSelectCmd, conn); 278 //2.1设置查询命令的参数 279 da.SelectCommand.Parameters.AddRange(paras); 280 //3.数据表 281 DataTable dt = new DataTable(); 282 //4.将数据查询并填充到数据表中 283 da.Fill(dt); 284 //5.将DataTable转成泛型集合List<T2> 285 if (dt.Rows.Count > 0) 286 { 287 //6.创建泛型集合对象 288 List<T2> list = new List<T2>(); 289 //7.遍历数据行,将行数据存入 实体对象中,并添加到 泛型集合中list 290 foreach (DataRow row in dt.Rows) 291 { 292 //留言:等学完反射后再讲~~~~! 293 //7.1先获得泛型的类型(里面包含该类的所有信息---有什么属性啊,有什么方法啊,什么字段啊....................) 294 Type t = typeof(T2); 295 //7.2根据类型创建该类型的对象 296 T2 model = (T2)Activator.CreateInstance(t);// new MODEL.Classes() 297 //7.3根据类型 获得 该类型的 所有属性定义 298 PropertyInfo[] properties = t.GetProperties(); 299 //7.4遍历属性数组 300 foreach (PropertyInfo p in properties) 301 { 302 //7.4.1获得属性名,作为列名 303 string colName = p.Name; 304 //7.4.2根据列名 获得当前循环行对应列的值 305 object colValue = row[colName]; 306 //7.4.3将 列值 赋给 model对象的p属性 307 //model.ID=colValue; 308 p.SetValue(model, colValue, null); 309 } 310 //7.5将装好 了行数据的 实体对象 添加到 泛型集合中 O了!!! 311 list.Add(model); 312 } 313 return list; 314 } 315 } 316 return null; 317 } 318 #endregion 319 320 #region 6.查询结果集里的第一个单元格的值(单个值)-- 泛型版本 + static T ExcuteScalar<T>(string strSelectCmd, params SqlParameter[] paras) 321 /// <summary> 322 /// 查询结果集里的第一个单元格的值(单个值)-- 泛型版本 323 /// </summary> 324 /// <typeparam name="T">类型参数</typeparam> 325 /// <param name="strSelectCmd"></param> 326 /// <param name="paras"></param> 327 /// <returns></returns> 328 public static T ExcuteScalar<T>(string strSelectCmd, params SqlParameter[] paras) 329 { 330 using (SqlConnection conn = new SqlConnection(strConn)) 331 { 332 SqlCommand cmd = new SqlCommand(strSelectCmd, conn); 333 cmd.Parameters.AddRange(paras); 334 conn.Open(); 335 object o = cmd.ExecuteScalar(); 336 return (T)Convert.ChangeType(o, typeof(T)); 337 } 338 } 339 #endregion 340 341 #region 将数据表 转成对应 T2 类型的泛型集合对象 342 /// <summary> 343 /// 将数据表 转成对应 T2 类型的泛型集合对象 344 /// </summary> 345 /// <typeparam name="T2">泛型类型</typeparam> 346 /// <returns>泛型集合</returns> 347 public static List<T2> Table2List<T2>(DataTable dt) 348 { 349 //5.将DataTable转成泛型集合List<T2> 350 if (dt.Rows.Count > 0) 351 { 352 //6.创建泛型集合对象 353 List<T2> list = new List<T2>(); 354 //7.遍历数据行,将行数据存入 实体对象中,并添加到 泛型集合中list 355 foreach (DataRow row in dt.Rows) 356 { 357 //留言:等学完反射后再讲~~~~! 358 //7.1先获得泛型的类型(里面包含该类的所有信息---有什么属性啊,有什么方法啊,什么字段啊....................) 359 Type t = typeof(T2); 360 //7.2根据类型创建该类型的对象 361 T2 model = (T2)Activator.CreateInstance(t);// new MODEL.Classes() 362 //7.3根据类型 获得 该类型的 所有属性定义 363 PropertyInfo[] properties = t.GetProperties(); 364 //7.4遍历属性数组 365 foreach (PropertyInfo p in properties) 366 { 367 //7.4.1获得属性名,作为列名 368 string colName = p.Name; 369 //7.4.2根据列名 获得当前循环行对应列的值 370 object colValue = row[colName]; 371 //7.4.3将 列值 赋给 model对象的p属性 372 //model.ID=colValue; 373 p.SetValue(model, colValue, null); 374 } 375 //7.5将装好 了行数据的 实体对象 添加到 泛型集合中 O了!!! 376 list.Add(model); 377 } 378 return list; 379 } 380 return null; 381 } 382 #endregion 383 384 public static void PrepareCommand(SqlCommand cmd, SqlConnection conn,SqlTransaction trans, CommandType type, string cmdText, SqlParameter[] cmdParms) 385 { 386 if (conn.State != ConnectionState.Open) conn.Open(); 387 cmd.Connection = conn; 388 cmd.CommandText = cmdText; 389 cmd.CommandType = type; 390 if (trans != null) cmd.Transaction = trans; 391 if (cmdParms != null) 392 { 393 foreach (SqlParameter parameter in cmdParms) 394 { 395 if ((parameter.Direction == ParameterDirection.InputOutput || parameter.Direction == ParameterDirection.Input) && 396 (parameter.Value == null)) 397 { 398 parameter.Value = DBNull.Value; 399 } 400 cmd.Parameters.Add(parameter); 401 } 402 } 403 } 404 } 405 }