zoukankan      html  css  js  c++  java
  • 分享我的数据处理类库,欢迎拍砖

    说明:首先在实体类中定义Attribute对象(主要包括表、字段信息),然后通过反射读取该对象信息,再进行数据处理

        一、类关系图如下:

    二、各类用途说明

        BaseEntity:实体类的基类,实体类必须继承该类。

        TableConfig/FieldConfig:描述表及字段配置信息,其中FieldConfig包括FieldName(字段名称)、DataType(数据类型)、Size(字段大小)、IsInsert(是否Insert操作)、IsUpdate(是否Update操作)五个字段信息。

        QueryHelper:查询对象。

        SplitPageParameter:分页对象。

        IDbProvider:数据处理接口。

        OperationAction:数据操作枚举。

        DataProvider:实现IDbProvider接口,并提供基础数据操作。

        SqlDbProvider/OleDbProvider:继承自DataProvider并提供相应操作。

        DataFactory:向外部提供IDbProvider服务。

    三、配置文件需提供如下信息:

    Code

        CNT:数据连接字符串

        DBTYPE:数据库类型(目前只支持MSSQL/OLEDB)

        EntityFile:实体类程序集信息

    四、接口说明:

            void Save(BaseEntity info):保存实体类

            void Update(BaseEntity info, QueryHelper query):根据条件更新实体类

            void Delete(QueryHelper query):根据条件删除数据

            BaseEntity Find(QueryHelper query):根据条件读取一条数据

            List<BaseEntity> Finds(QueryHelper query):根据条件读取多条数据

            List<BaseEntity> Finds(SplitPageParameter sp):根据条件分页读取数据

            void UpdateFields(string tableName, string[] fieldNames, object[] fieldValues, QueryHelper query):根据条件更新指定表的指定字段

     五、核心函数说明

          (1)、DataProvider.cs

    Code

          此函数根据对象类型,通过反射获取实体类信息及实体类字段值,然后组织SQL语句为IDbCommand赋值

     源码下载

    应用场景:

         适合数据处理较小的应用

    使用:

    Code

    欢迎大家拍砖

  • 相关阅读:
    Xenu Link Sleuth简单使用
    C#简单游戏外挂制作(以Warcraft Ⅲ为例)
    Silverlight InkPresenter 实现路径回放的探索
    Microsoft Virtual Earth Silverlight Map Control (CTP)快速上手
    【Azure实例】有趣的Silverlight应用:录播简笔画
    Azure Services Platform 入门系列文章索引页
    javascript原型的类继承
    javascript给类添加的方法
    checkbox 全选
    【nodejs】 在 Ubuntu 12.04 安裝 Node.js【转】
  • 原文地址:https://www.cnblogs.com/land/p/dblib.html
Copyright © 2011-2022 走看看