范式理论的程序设计(四)

这篇博客探讨了数据库范式理论在程序设计中的应用,主要关注ArmstrongUtils工具类。文章详细介绍了该工具类的接口设计,以及自反律、增补律、传递律、合并律、分解律和伪传递律这六大公理的实现方法和测试代码。内容以Java编程语言为载体,展示了如何将这些理论融入实际编程中。
摘要由CSDN通过智能技术生成

关于数据库范式理论的程序设计 - ArmstrongUtils

这里我使用的工具类全部都是使用接口,public interface ArmstrongUtils extends CollectionUtils是关于Armstrong公理的工具,因为后面算法都不用就算F+,所有这些性质都很少会直接用到重点内容

Utils工具的继承关系

这里写图片描述

ArmstrongUtils接口

import com.ruoxing.dbs.bean.FunctionalDependency;

/**
 * @author :ruoxing
 * @type :Interface
 * @date :2018年5月
 * @description :Armstrong公理
 */
public interface ArmstrongUtils extends CollectionUtils {
   
}

这里写图片描述

自反律(reflexivity)

1. 方法代码

    /**
     * 描述:自反律: β包含于α  => α → β
     * @param sequenceA α
     * @param sequenceB β
     * @return FunctionalDependency  α → β
     */
    default FunctionalDependency reflexivity(CharSequence sequenceA, CharSequence sequenceB) {
        if (contains(sequenceA, sequenceB)) {
            return new FunctionalDependency(sequenceA, sequenceB);
        }
        return null;
    }

2. 测试代码(Junit)

import com.ruoxing.dbs.bean.FunctionalDependency;
import com.ruoxing.dbs.util.ArmstrongUtils;
import org.junit.Test;

import java.util.Arrays;

/**
 * 描述:测试Armstrong公理的实现
 */
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值