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

    欢迎大家拍砖

  • 相关阅读:
    Expert C programming书摘
    修改文件时间属性的方法
    算法学习, 开始计划
    小游戏学习搜集
    C++ 练习记录2---Effective STL中的vector<bool>
    C++ 练习记录1--vector<T> 中T的初始化
    oracle的wm_concat函数实现行转列
    Oracle批量插入有日期类型数据
    如何将zTree选中节点传递给后台
    第五章:1.数组和广义表 -- 数组
  • 原文地址:https://www.cnblogs.com/land/p/dblib.html
Copyright © 2011-2022 走看看