通用权限管理系统组件 (GPM - General Permissions Manager) 中灵活经典的.NET2.0数据库访问组件,附源码

简介:

  情人节的晚上思绪万千,想到了曾经的N次恋爱,想到现在生活,想到曾经的奋斗,想到曾经在身边的女人,人生不易终于失眠了,上一篇我们介绍了 通用权限管理系统组件 (GPM - General Permissions Manager) 中超级经典的.NET2.0静态数据库访问组件 两者的区别就是一个是 static 的方法,另外一个是通过接口的方式实现的,接着我们介绍更加灵活的,动态数据库5种实用方法,与上一篇的数据库访问组件结合实用会更加强大一些,真正功能强大的是没任何封装的ADO.NET,其实自己封装的往往都是有些娱乐精神的人干出来的事情。

  当然这些数据库访问组件都是可以单独使用的,可以与通用权限管理系统组件无任何关联。通用权限的很多实现理念就是无关性,通用权限与数据库访问组件是无关的,数据库库访问组件就可以单独用,甚至没任何无用的代码,配置在里面。

  我们直接看代码如下:

// -----------------------------------------------------------------
//  All Rights Reserved , Copyright (C) 2012 , Hairihan TECH, Ltd. 
// -----------------------------------------------------------------

using System;
using System.Data;
using System.Collections.Generic;

using DotNet.Utilities;
using DotNet.Business;

/// <summary>
///  DbTools2
///  静态数据库访问的方法程序
///
///  修改纪录
///
///         2012-02-15 版本:1.0 JiRiGaLa 整理例子程序功能。
///
///  版本:1.0
///
/// <author>
/// <name> JiRiGaLa </name>
/// <date> 2012-02-15 </date>
/// </author>
/// </summary>
public partial class DbTools2 : BasePage
{
protected void Page_Load( object sender, EventArgs e)
   {
//  动态方法调用数据库的方法
this.DynamicMethod();

//  动态打开数据库的方法
string dbConnection =  " Data Source=localhost;Initial Catalog=UserCenterV36;User Id = sa ; Password = Password@1234; ";
//  using (IDbHelper dbHelper = DbHelperFactory.GetHelper(CurrentDbType.Oracle))
//  using (IDbHelper dbHelper = DbHelperFactory.GetHelper(CurrentDbType.MySql))
//  using (IDbHelper dbHelper = DbHelperFactory.GetHelper(CurrentDbType.DB2))
//  using (IDbHelper dbHelper = DbHelperFactory.GetHelper(CurrentDbType.Access))
//  using (IDbHelper dbHelper = DbHelperFactory.GetHelper(CurrentDbType.SQLite))
using (IDbHelper dbHelper = DbHelperFactory.GetHelper(CurrentDbType.SqlServer))
       {
           dbHelper.Open(dbConnection);
       }
   }

private void DynamicMethod()
   {
this.Fill();
this.ExecuteNonQuery();
this.ExecuteScalar();
this.ExecuteReader();
   }


/// <summary>
///  Fill
///  动态方法调用数据库的方法,能有效控制数据库的开关次数
/// </summary>
private void Fill()
   {
string dbConnection =  " Data Source=localhost;Initial Catalog=UserCenterV36;User Id = sa ; Password = Password@1234; ";
//  DotNet.Utilities.IDbHelper dbHelper = new DotNet.Utilities.DB2Helper(dbConnection);
//  DotNet.Utilities.IDbHelper dbHelper = new DotNet.Utilities.MySqlHelper(dbConnection);
//  DotNet.Utilities.IDbHelper dbHelper = new DotNet.Utilities.OleDbHelper(dbConnection);
//  DotNet.Utilities.IDbHelper dbHelper = new DotNet.Utilities.OracleHelper(dbConnection);
//  DotNet.Utilities.IDbHelper dbHelper = new DotNet.Utilities.SqLiteHelper(dbConnection);
       DotNet.Utilities.IDbHelper dbHelper =  new DotNet.Utilities.SqlHelper(dbConnection);
       dbHelper.Open();

//  1:直接执行
string commandText =  @" SELECT * 
                                FROM BASE_USER 
                               WHERE DELETIONSTATECODE = 0
";
       DataTable dataTable = dbHelper.Fill(commandText);

//  2:防注入的安全的参数化运行方式执行查询
       commandText =  @"  SELECT * 
                         FROM BASE_USER 
                        WHERE CODE = 
" + dbHelper.GetParameter( " Code ")
                              +  "  AND DELETIONSTATECODE =  " + dbHelper.GetParameter( " DeletionStateCode ");
//  这里是生成安全参数的方法
       List<IDbDataParameter> dbParameters =  new List<IDbDataParameter>();
       dbParameters.Add(dbHelper.MakeParameter( " Code "" jirigala "));
       dbParameters.Add(dbHelper.MakeParameter( " DeletionStateCode "0));
       dataTable = dbHelper.Fill(commandText, dbParameters.ToArray());

//  3:执行存储过程,假设也是需要传递这2个参数,类似功能的一个存储过程
//     我们不建议用存储过程,因为会对系统移植,多数据库设计等上会遇到很多麻烦
       commandText =  " GET_USER ";
       dataTable = dbHelper.Fill(commandText, dbParameters.ToArray(), CommandType.StoredProcedure);
       dbHelper.Close();
   }


/// <summary>
///  ExecuteNonQuery
///  静态方法调用数据库的方法,调用事物的方式
/// </summary>
/// <returns> 影响行数 </returns>
private int ExecuteNonQuery()
   {
int returnValue =  0;

string dbConnection =  " Data Source=localhost;Initial Catalog=UserCenterV36;User Id = sa ; Password = Password@1234; ";
       DotNet.Utilities.IDbHelper dbHelper =  new DotNet.Utilities.SqlHelper(dbConnection);
try
       {
           dbHelper.Open();
           dbHelper.BeginTransaction();

//  1:直接执行
string commandText =  @" UPDATE BASE_USER
                               SET DELETIONSTATECODE = 0
";
           returnValue = dbHelper.ExecuteNonQuery(commandText);

//  2:防注入的安全的参数化运行方式执行查询
           commandText =  @"  UPDATE BASE_USER 
                       SET DELETIONSTATECODE = 0
                       WHERE CODE = 
" + DotNet.Utilities.DbHelper.GetParameter( " Code ")
                                   +  "  AND DELETIONSTATECODE =  " + DotNet.Utilities.DbHelper.GetParameter( " DeletionStateCode ");
//  这里是生成安全参数的方法
           List<IDbDataParameter> dbParameters =  new List<IDbDataParameter>();
           dbParameters.Add(dbHelper.MakeParameter( " Code "" jirigala "));
           dbParameters.Add(dbHelper.MakeParameter( " DeletionStateCode "0));
           returnValue = dbHelper.ExecuteNonQuery(commandText, dbParameters.ToArray());

//  3:执行存储过程,假设也是需要传递这2个参数,类似功能的一个存储过程
//     我们不建议用存储过程,因为会对系统移植,多数据库设计等上会遇到很多麻烦
           commandText =  " UPDATE_USER ";
           returnValue = dbHelper.ExecuteNonQuery(commandText, dbParameters.ToArray(), CommandType.StoredProcedure);

           dbHelper.CommitTransaction();
       }
catch (Exception ex)
       {
           dbHelper.RollbackTransaction();
           BaseExceptionManager.LogException(dbHelper,  this.UserInfo, ex);
throw ex;
       }
finally
       {
           dbHelper.Close();
       }
return returnValue;
   }


/// <summary>
///  ExecuteScalar
///  动态方法调用数据库的方法, 支持Using的用法
/// </summary>
/// <returns> 结果 </returns>
private object ExecuteScalar()
   {
object returnValue =  null;

string dbConnection =  " Data Source=localhost;Initial Catalog=UserCenterV36;User Id = sa ; Password = Password@1234; ";
using (DotNet.Utilities.IDbHelper dbHelper =  new DotNet.Utilities.SqlHelper(dbConnection))
       {
//  1:直接执行
string commandText =  @" SELECT CODE 
                                FROM BASE_USER 
                               WHERE DELETIONSTATECODE = 0
";
           returnValue = dbHelper.ExecuteScalar(commandText);

//  2:防注入的安全的参数化运行方式执行查询
           commandText =  @"  SELECT CODE 
                          FROM BASE_USER 
                         WHERE  CODE = 
" + dbHelper.GetParameter( " Code ")
                                  +  "  AND DELETIONSTATECODE =  " + dbHelper.GetParameter( " DeletionStateCode ");
//  这里是生成安全参数的方法
           List<IDbDataParameter> dbParameters =  new List<IDbDataParameter>();
           dbParameters.Add(dbHelper.MakeParameter( " Code "" jirigala "));
           dbParameters.Add(dbHelper.MakeParameter( " DeletionStateCode "0));
           returnValue = dbHelper.ExecuteScalar(commandText, dbParameters.ToArray());

//  3:执行存储过程,假设也是需要传递这2个参数,类似功能的一个存储过程
//     我们不建议用存储过程,因为会对系统移植,多数据库设计等上会遇到很多麻烦
           commandText =  " GET_USER ";
           returnValue = dbHelper.ExecuteScalar(commandText, dbParameters.ToArray(), CommandType.StoredProcedure);
       }

return returnValue;
   }


/// <summary>
///  ExecuteReader
///  动态方法调用数据库的方法,每次执行程序会自动打开关闭数据库的例子,自动会多次打开关闭
/// </summary>
private void ExecuteReader()
   {
string dbConnection =  " Data Source=localhost;Initial Catalog=UserCenterV36;User Id = sa ; Password = Password@1234; ";
       DotNet.Utilities.IDbHelper dbHelper =  new DotNet.Utilities.SqlHelper(dbConnection);

//  1:直接执行
string commandText =  @" SELECT * 
                                FROM BASE_USER
                               WHERE DELETIONSTATECODE = 0
";
       dbHelper.ExecuteReader(commandText);

//  2:防注入的安全的参数化运行方式执行查询
       commandText =  @"  SELECT * 
                          FROM BASE_USER
                         WHERE CODE = 
" + dbHelper.GetParameter( " Code ")
                              +  "  AND DELETIONSTATECODE =  " + dbHelper.GetParameter( " DeletionStateCode ");
//  这里是生成安全参数的方法
       List<IDbDataParameter> dbParameters =  new List<IDbDataParameter>();
       dbParameters.Add(dbHelper.MakeParameter( " Code "" jirigala "));
       dbParameters.Add(dbHelper.MakeParameter( " DeletionStateCode "0));
       dbHelper.ExecuteReader(commandText, dbParameters.ToArray());

//  3:执行存储过程,假设也是需要传递这2个参数,类似功能的一个存储过程
//     我们不建议用存储过程,因为会对系统移植,多数据库设计等上会遇到很多麻烦
       commandText =  " GET_USER ";
       dbHelper.ExecuteReader(commandText, dbParameters.ToArray(), CommandType.StoredProcedure);
   }
}


  例子程序下载地址如下:

/Files/jirigala/CRM.rar

  .NET 2.0 数据库访问层源码在这里下载:

/Files/jirigala/DotNet.Utilities.rar





本文转自 jirigala 51CTO博客,原文链接:http://blog.51cto.com/2347979/1196327,如需转载请自行联系原作者
相关文章
|
2月前
|
SQL Java 数据库连接
除了JDBC,还有哪些常见的数据库访问技术?
除了JDBC,还有哪些常见的数据库访问技术?
251 2
|
8月前
|
运维 监控 数据可视化
一文拆解 YashanDB Cloud Manager,数据库运维原来还能这么“智能”!
传统数据库运维依赖人工,耗时耗力还易出错。YashanDB Cloud Manager(YCM)作为“智能运维管家”,实现主动、智能、可视化的运维体验。它提供实时资源监控、智能告警系统、自动巡检机制、高可用架构支持和强大的权限管理功能,帮助用户统一管理多实例与集群,减少人工干预,构建现代化数据库运维体系,让企业高效又安心地运行数据库服务。
|
3月前
|
JavaScript API PHP
WordPress/Laravel企业官网源码-自适应多端SEO-前后端分离源码含数据库与部署文档​
本文详解如何结合WordPress与Laravel构建现代化企业官网,涵盖响应式设计、SEO优化、前后端分离、数据库安全及自动化部署。通过实战案例展示性能提升成果,并展望AI、云原生与区块链的未来融合方向,助力企业实现数字化增长。
|
8月前
|
前端开发 数据库
会议室管理系统源码(含数据库脚本)
会议室管理系统源码(含数据库脚本)
142 0
|
8月前
|
Java 关系型数据库 MySQL
Java汽车租赁系统源码(含数据库脚本)
Java汽车租赁系统源码(含数据库脚本)
178 4
|
9月前
|
前端开发 Java 关系型数据库
基于ssm的社区物业管理系统,附源码+数据库+论文+任务书
社区物业管理系统采用B/S架构,基于Java语言开发,使用MySQL数据库。系统涵盖个人中心、用户管理、楼盘管理、收费管理、停车登记、报修与投诉管理等功能模块,方便管理员及用户操作。前端采用Vue、HTML、JavaScript等技术,后端使用SSM框架。系统支持远程安装调试,确保顺利运行。提供演示视频和详细文档截图,帮助用户快速上手。
385 17
|
9月前
|
前端开发 Java 关系型数据库
基于ssm的培训学校教学管理平台,附源码+数据库+论文
金旗帜文化培训学校网站项目包含管理员、教师和用户三种角色,各角色功能通过用例图展示。技术框架采用Java语言,B/S架构,前端为Vue+HTML+CSS+LayUI,后端为SSM,数据库为MySQL,运行环境为JDK8+Tomcat8.5。项目含12张数据库表,非前后端分离,支持演示视频与截图查看。购买后提供免费安装调试服务,确保顺利运行。
186 14
|
3月前
|
缓存 关系型数据库 BI
使用MYSQL Report分析数据库性能(下)
使用MYSQL Report分析数据库性能
154 3
|
3月前
|
关系型数据库 MySQL 数据库
自建数据库如何迁移至RDS MySQL实例
数据库迁移是一项复杂且耗时的工程,需考虑数据安全、完整性及业务中断影响。使用阿里云数据传输服务DTS,可快速、平滑完成迁移任务,将应用停机时间降至分钟级。您还可通过全量备份自建数据库并恢复至RDS MySQL实例,实现间接迁移上云。
|
3月前
|
关系型数据库 MySQL 分布式数据库
阿里云PolarDB云原生数据库收费价格:MySQL和PostgreSQL详细介绍
阿里云PolarDB兼容MySQL、PostgreSQL及Oracle语法,支持集中式与分布式架构。标准版2核4G年费1116元起,企业版最高性能达4核16G,支持HTAP与多级高可用,广泛应用于金融、政务、互联网等领域,TCO成本降低50%。