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

    欢迎大家拍砖

  • 相关阅读:
    蛙蛙推荐:JS里声明事件处理的几种方式
    蛙蛙推荐:asp错误处理
    蛙蛙推荐:偶心目中的编程高手,大家也推荐一下
    access能否用vbs来写存储过程,是否支持参数名称 【星期一 2005年7月4日】
    MySQL索引相关
    ubuntu 禁用触摸板
    ubuntuFQ(转)
    bash编程笔记
    Hive环境搭建与入门(转)
    Linux SSH远程文件/目录传输命令scp
  • 原文地址:https://www.cnblogs.com/land/p/dblib.html
Copyright © 2011-2022 走看看