【自然框架 NatureFW】里的两种“映射”方式

简介:    自然框架里面采用了两种映射关系,一个是流行的ORM,另一是非主流的“CCM ” (我自己想的,呵呵)。   先说一下ORM。ORM是O和R的映射关系。也看到很多人写关于ORM的文章,发现好像有个误区。

  

自然框架里面采用了两种映射关系,一个是流行的ORM,另一是非主流的“CCM ” (我自己想的,呵呵)。

 

先说一下ORMORMOR的映射关系。也看到很多人写关于ORM的文章,发现好像有个误区。这个误区就是,要么根据数据库来生成实体类,要么根据实体类(UML)来生成数据库。ORM有这么简单吗?这个误区导致了一个很严重的问题——滥用!!

 

用好ORM的关键,我举的在于:设计O的时候是否会受到R的影响;同理,设计R的时候,是否受到了O的影响?也就是说设计实体类的时候,完全不去考虑数据库,设计数据库的时候也完全不考虑实体类!

 

用实际的工作经历来说明一下。我在做设计的时候,先根据需求设计数据库,这时候完全没有考虑类要如何设计(其实一开始根本就没有用实体类,呵呵)。

 

后来框架不断扩展,发现个问题:不弄个实体类来管理一下,确实挺麻烦的。那么如何来设计需要的类呢?

 

有一个表就建立一个类,表里的字段都是类的属性吗?真的是真么简单吗

 

既然要设计类,那么就要把表结构忘掉,完全按照实际需求和面向对象的要求来设计。然后类和数据库都设计好了之后,再去考虑如何映射。我觉得只有这样做的才是真正的ORM

 

比如:自然框架元数据的数据库里有一个表“Manage_Columns”,他是记录字段的基本信息(字段名、字段类型、字段大小等)和验证信息、控件描述等。因为这些信息都是跟随字段的,所以就都放在了一个表里面。

 

实体类里有一个类“ColumnMeta”,他的属性只有字段的基本信息,没有验证信息等。这是因为这个信息是很多地方都需要用到,而验证信息并不是必须的。只有页面表单里面才需要,“数据列表”和“数据查询”都不需要。

 

这样一来,表和类就不是完全对应,而是把一个表“拆开”了,对应多个类。

 

在比如:表单里的控件有很多种类,文本框、下拉列表框、多选等,而文本框有分为单行、多行、密码等,还有日期选择等等情况。那么如何来描述这些不同类型的控件呢?把属性都拿出来做成字段?还是把不同的控件都拿出来做成表?

 

这两种方法都有很明显的缺点——不便于维护!多一种控件,就要多一些字段,或者多一个表。这样就给扩展带来了麻烦,修改的时候也很麻烦!想一想,自然框架推广了(假设一下,呵呵)。好多人都在用,突然告诉大家,数据库里要多两个字段。不把这两个字段加上,就不能用新版本。这是一件多么麻烦的事情呀。

 

要尽量避免这种事情,那么要怎么处理呢?我的解决方法就是——在数据库里就设置一个字段,然后把描述信息都放进去。一开始采用~来分隔,后来发现不太便于查看。于是现在新版本采用json的格式来做控件信息的描述。然后把整个描述信息放在一个字段里。这样怎么扩展,数据库都不需要有变化了。

 

再来看看实体类的设计。数据库里用一个字段,那么实体类不能只有一个属性来表示,这样就太不方便了。于是设计了一套类。如下图。采用基类的方式。这样,数据库里的一个字段,就对应了一套类。

 

 

=====================================================

 

另外ORM还有一个小问题,就是ORM的粒度只是做到实体类和表并没有做字段。在ORM里字段是不能独立存在的,这样就造成了一个麻烦——多表关联的怎么办?

 

所以就想出来了——CCM

 

CCM是啥呢?就是 control column的映射。页面里的控件和数据库里的字段,直接对应起来。

 

Control指的是文本框、下拉列表框这一类的控件,不包括GridView这一类的控件。

  

我是用一种“映射”,把字段和控件关联起来,实现快速开发。他的粒度更细了一层,字段是可以独立出来的,并不限于一个表内。于是字段就可以“复用”。一个字段(的描述信息)就是一条记录,表单里需要的字段就是一个集合,数据列表里需要的字段是另一个集合……这样就非常方便。这样处理带来了很多好处,最明显的就是——权限到字段!

 

 

 

 

 

 

 

 

 

相关文章
|
7月前
|
JavaScript 前端开发 Java
函数形状的定义方式在编程中可以有多种,具体取决于使用的编程语言和上下文。以下是几种常见的定义方式:
函数形状的定义方式在编程中可以有多种,具体取决于使用的编程语言和上下文。以下是几种常见的定义方式:
51 3
|
3月前
|
机器学习/深度学习 人工智能 自然语言处理
大模型的特点、重要概念及工作方式详解
大模型是具有大量参数和复杂结构的深度学习模型,通过处理大量数据实现高效任务解决。其特点包括参数规模庞大、深层网络结构、预训练与微调、多任务学习和自适应能力。重要概念有注意力机制、Transformer架构、迁移学习和分布式训练。大模型的工作方式包括输入处理、特征提取、预测与损失计算、反向传播与优化,以及评估与微调。这些特性使其在自然语言处理、计算机视觉等领域取得显著进展。
317 0
|
8月前
|
C++
C++ 接口的实现,及作用通俗理解方式
C++中的接口,一般就是指抽象类,是一种用来描述类对外提供的操作、方法或功能的集合——注意,一般只是描述(声明),而不对这些方法或功能进行定义实现,通常在
74 2
|
安全
RxSwift特征序列Driver的使用,以及共享附加作用与非共享附加作用的区别?
RxSwift特征序列Driver的使用,以及共享附加作用与非共享附加作用的区别?
185 0
|
关系型数据库 MySQL 数据库
数据库技术知识点(一)IDEFO需求建模方法、解释实体、实体型、实体集的区别、完全函数依赖、部分函数依赖、传递函数、平凡函数依赖、非平凡函数依赖举例、超码、主码、候选码的概念与区分
数据库技术知识点(一)IDEFO需求建模方法、解释实体、实体型、实体集的区别、完全函数依赖、部分函数依赖、传递函数、平凡函数依赖、非平凡函数依赖举例、超码、主码、候选码的概念与区分
数据库技术知识点(一)IDEFO需求建模方法、解释实体、实体型、实体集的区别、完全函数依赖、部分函数依赖、传递函数、平凡函数依赖、非平凡函数依赖举例、超码、主码、候选码的概念与区分
|
Java Apache
集合的特别要注意地方哈
《系统设计》系列
80 0
|
SQL
【自然框架】——自然框架的命名空间
  为什么要有命名空间?类多了不便于管理,把他们给他分个类整理一下,便于管理。     那么命名空间就有了两个使命,分类和标识。其实标识也是一种分类。   我们打开Reflector.exe看看.net框架里的命名空间。
830 0
【自然框架】内部类库、控件的引用关系(最新整理,基本稳定)
  和以前相比,减少了一个项目,把Control_Interface合并到CommonFunction里面。这样引用关系就简单多了。   基本上分为三个层次:类库、自定义控件、页面基类。其中的 MetaData 负责元数据的定义和加载。
650 0
|
算法
自然框架,拆分后的项目关系
  拆分了一下自然框架,似乎又绕回去了。以前是多个项目分开放的,有人说太分散了,还得一个个下载,麻烦。于是就做了一个解决方案,把项目都放在了一起。     现在呢,QuickPager分页控件比较完善了,有人只想看分页控件的代码,其他的不想看,东西太多了乱。
882 0
【自然框架】 页面里的父类—— (补充)
没想到下午发的《【自然框架】 页面里的父类——把共用的东东都交给父类,让子类专注于其他。 》启发了热烈讨论,还以为又是一大堆的口水回复呢。看到大家的热烈讨论我很高兴,这才是我希望的讨论环境,无论是支持的还是反对的,我都非常感谢。
979 0