日期:2014-05-16  浏览次数:20555 次

读《企业应用架构模式》6--映射到关系数据库

读《企业应用架构模式》6--映射到关系数据库

 

Author:zfive5(zhaozidong)

Email:zfive5@163.com

 

读完这章,唯一的感觉是如果5年前好好拜读一下,就不至于走许多弯路了,现在产品中也的确好多地方本章里去实践的。从开始领域建模,再到物理数据的存储在单表继承,具体表继承和类表继承,每一种模式应用时也考虑过它们的优与劣。

 

单表继承:对“标识列”的解释,因为太多的无逻辑的“业务逻辑”,照成“此列无它用”。但考虑到报表还是有选择道理。在场景1A1类型记录多,A2类型记录少,但只访问A2类型的数据是也要为整体数据付出代价。当然这种可以用索引来解决,但插入在稍后有成了问题。真可谓步步惊心!

 

具体表继承:隔绝了兄弟姐妹之间相互的影响;但接下来统一又左右为难。克服方法可以引入第3张表或视图。当然也是有困难的。

 

类表继承:单表继承+具体表继承,但往往西瓜和芝麻真的不能全得。世间真没有Win-Win

 

书中作者更倾向第一种,的确它也是我们在产品实践的首选。

 

关于映射要元数据,我有些其他的想法,因为我们这类人太容易创造新东西,10个我,就会有10Idea,最后造成要所有的人去熟悉10Idea,又是成本。是否可以有一种自我描述体系,对象模型+贴身元数据更好些。请注意AttributeAnnotate

 

select *的问题大家都已经很熟悉了,但深层次的问题是效率问题才是根本。如果你为了select *开脱必然会想到用DataTable[0]["Name"]但让我用反射看到.NETDataTable代码:

 

[ResDescription("DataTableColumnsDescr"), DesignerSerializationVisibility(DesignerSerializationVisibility.Content), ResCategory("DataCategory_Data")]
public DataColumnCollection Columns
{
    get
    {
        return this.columnCollection;
    }
}
 
public DataColumn this[string name]
{
    get
    {
        if (name == null)
        {
            throw ExceptionBuilder.ArgumentNull("name");
        }
        DataColumn column = this.columnFromName[name] as DataColumn;
        if (column == null)
        {
            int num = this.IndexOfCaseInsensitive(name);
            if (0 <= num)
            {