sql if语句嵌套去重计数_sql去掉某个字段重复的数据

sql if语句嵌套去重计数_sql去掉某个字段重复的数据

1.简介

if判断语句是很多编程语言的重要组成部分。但是,若我们最终编写了大量嵌套的if语句,这将使得我们的代码更加复杂和难以维护。

让我们看看能否使用别的方式来做呢。

设计模式是为了更好的代码重用性,可读性,可靠性,可维护性,它有六大原则

1)单一职责原则(Single Responsibility Principle,简称SRP):该原则是针对类来说的,即一个类应该只负责一项职责.

2)开放–封闭原则(The Open-Closed Principle简称OCP):是说软件实体(类、模块、函数等等)应该可以扩展,但是不可以修改。

3)依赖倒转原则(Dependence Inversion Principle :针对接口编程,不要对实现编程

4)里氏代换原则(Liskov Substitution Principle,简称LSP):里氏代换原则,子类型必须能够替换掉他们的父类型

5)迪米特法则(Law of Demeter):如果两个类不必彼此直接通信,那么这两个类就不应当发生直接的相互作用

6)合成/聚合复用原则(Composition/Aggregation Principle],简称CARP):尽量使用合成/聚合,尽量不使用类继承。合成聚合是“has a”的关系,而继承是“is a”的关系。

2.示例

if..else

public int calculate(int a, int b, String operator) { int result = Integer.MIN_VALUE; if (“add”.equals(operator)) { result = a + b; } else if (“multiply”.equals(operator)) { result = a * b; } else if (“divide”.equals(operator)) { result = a / b; } else if (“subtract”.equals(operator)) { result = a – b; } else if (“modulo”.equals(operator)) { result = a % b; } return result; }

case-switch

public int calculateUsingSwitch(int a, int b, String operator) { int result = 0; switch (operator) { case “add”: result = a + b; break; case “multiply”: result = a * b; break; case “divide”: result = a / b; break; case “subtract”: result = a – b; break; case “modulo”: result = a % b; break; default: result = Integer.MIN_VALUE; } return result; }

3.重构

3.1 工厂方式重构

抽象层Operation.java

public interface Operation { int apply(int a, int b); }

加法实现Addition.java:

public class Addition implements Operation { @Override public int apply(int a, int b) { return a + b; } }

减法实现Subtraction.java

public class Subtraction implements Operation { @Override public int apply(int a, int b) { return a – b; } }

乘法实现Multiplication.java

public class Multiplication implements Operation { @Override public int apply(int a, int b) { return a*b; } }

除法实现Division.java

public class Division implements Operation { @Override public int apply(int a, int b) { return a / b; } }

求余实现Modulo.java

public class Modulo implements Operation { @Override public int apply(int a, int b) { return a % b; } }

工厂类OperatorFactory.java

import java.util.HashMap; import java.util.Map; import java.util.Optional; public class OperatorFactory { static Map<String, Operation> operationMap = new HashMap<>(); static { operationMap.put(“add”, new Addition()); operationMap.put(“divide”, new Division()); operationMap.put(“multiply”, new Multiplication()); operationMap.put(“subtract”, new Subtraction()); operationMap.put(“modulo”, new Modulo()); } public static Optional<Operation> getOperation(String operation) { return Optional.ofNullable(operationMap.get(operation)); } }

使用示例

public int calculateUsingFactory(int a, int b, String operator) { Operation targetOperation = OperatorFactory .getOperation(operator) .orElseThrow(() -> new IllegalArgumentException(“Invalid Operator”)); return targetOperation.apply(a, b); }

3.2 枚举方式重构

枚举实现Operator.java

public enum Operator { ADD { @Override public int apply(int a, int b) { return a + b; } }, MULTIPLY { @Override public int apply(int a, int b) { return a * b; } }, SUBTRACT { @Override public int apply(int a, int b) { return a – b; } }, DIVIDE { @Override public int apply(int a, int b) { return a / b; } }, MODULO { @Override public int apply(int a, int b) { return a % b; } }; public abstract int apply(int a, int b); }

封装Operator到Calculator.java

public int calculate(int a, int b, Operator operator) { return operator.apply(a, b); }

使用示例

@Test public void whenCalculateUsingEnumOperator_thenReturnCorrectResult() { Calculator calculator = new Calculator(); int result = calculator.calculate(3, 4, Operator.valueOf(“ADD”)); assertEquals(7, result); }

3.3 命令模式

抽象的接口

public interface Command { Integer execute(); }

实现类

package com.baeldung.reducingIfElse; public class AddCommand implements Command { private int a; private int b; public AddCommand(int a, int b) { this.a = a; this.b = b; } @Override public Integer execute() { return a + b; } }

其它略

包装

public int calculate(Command command) { return command.execute(); }

测试demo

@Test public void whenCalculateUsingCommand_thenReturnCorrectResult() { Calculator calculator = new Calculator(); int result = calculator.calculate(new AddCommand(3, 7)); assertEquals(10, result); }

4.规则引擎重构

抽象规则

public interface Rule { boolean evaluate(Expression expression); Result getResult(); }

实现规则AddRule.java 其它略

public class AddRule implements Rule { private int result; @Override public boolean evaluate(Expression expression) { boolean evalResult = false; if (expression.getOperator() == Operator.ADD) { this.result = expression.getX() + expression.getY(); evalResult = true; } return evalResult; } @Override public Result getResult() { return new Result(result); } }

其中:返回结果

public class Result { int value; public Result(int value) { this.value = value; } public int getValue() { return value; } }

表达式

public class Expression { private Integer x; private Integer y; private Operator operator; public Expression(Integer x, Integer y, Operator operator) { this.x = x; this.y = y; this.operator = operator; } public Integer getX() { return x; } public Integer getY() { return y; } public Operator getOperator() { return operator; } }

规则引擎RuleEngine.java

import java.util.ArrayList; import java.util.List; import java.util.Optional; import java.util.stream.Collectors; public class RuleEngine { private static List<Rule> rules = new ArrayList<>(); static { rules.add(new AddRule()); } public Result process(Expression expression) { Rule rule = rules.stream() .filter(r -> r.evaluate(expression)) .findFirst() .orElseThrow(() -> new IllegalArgumentException(“Expression does not matches any Rule”)); return rule.getResult(); } }

测试demo

@Test public void whenNumbersGivenToRuleEngine_thenReturnCorrectResult() { Expression expression = new Expression(5, 5, Operator.ADD); RuleEngine engine = new RuleEngine(); Result result = engine.process(expression); assertNotNull(result); assertEquals(10, result.getValue()); }

4.小结

为了更好的代码重用性,可读性,可靠性,可维护性,我们会尝试将IF/ELSE或者case-switch进行改造,使用工厂方法,枚举方法,命令模式,规则引擎方式不同方法进行尝试,最后使用设计模式的六大原则对代码进行评估。

参考资料

【1】https://www.cnblogs.com/davidwang456/p/3641369.html

【2】https://www.baeldung.com/java-replace-if-statements

本文【sql if语句嵌套去重计数_sql去掉某个字段重复的数据】由作者: 悲观锁 提供,本站不拥有所有权,只提供储存服务,如有侵权,联系删除!
本文链接:https://www.cuoshuo.com/blog/4247.html

(0)
上一篇 2023-03-11 08:40:51
下一篇 2023-03-11 08:52:44

相关推荐

  • dos命令大全及用法pdf(dos内部命令)

    晚上好,我是老杨,今天来聊聊常用的DOS命令。 虽然是老古董,但不妨碍它的好用程度。可能一些新手不晓得,但是和老杨一个年纪的,一定对DOS系统不陌生。 尽管现在大多数电脑的操作系统是Windows,但在Windows 95推出以前,占统治地位的操作系统就是DOS。 DOS即Disk Operating System,我们常成为是磁盘操作系统。 由于Windo…

    2023-03-19
    000
  • dropdownlist怎么清空

    下拉列表,又称下拉框,是一个可切换列表,其中包含多个选项,一次只能选择一个选项。 当你需要从多个答案中选中某一个时,可以采用此部件。比如国家的选择/地区的选择等。 添加,删除和重新排序Droplist选项 9DropList.png 元件添加:直接从左侧元件库上拖入; 下拉列表的编辑:直接双击Droplist; 选项的添加:点击左侧上方添加按钮(上图中第一个…

    2023-03-20
    000
  • 学生信息管理系统代码_学生信息管理系统报告

    目 录 第一章 产品与服务介绍 第二章 软件工具的介绍 第三章 市场分析及定位介绍 第四章 商业模式 第五章 营销策略 第六章 财务分析 第七章 风险控制 第八章 团队介绍 第一章 产品与服务介绍 项目背景: 随着互联网用户群的越来越大,当前,全球互联网发展正进入泛在普及、深度融合、变革创新、引领转型的新阶段,对各国经济社会运行、生产生活方式、公共服务模式正…

    2023-03-11
    700
  • 数据库备份sql语句_sql语句在哪里写

    前言: 备份乃不死之王! 一、全表结构备份: SELECT INTO 语句:表示从一个表中选取数据,然后把数据插入另一个表中,常用来备份一张表 INSERT INTO new_table_name SELECT * FROM old_tablename;示例:备份student表,备份表取名为student_backup insert into studen…

    2023-03-11
    500
  • python udp通信(python的socket库)

    前言 前文使用TCP面向流的套接字,今天讲解的UDP的工作方式与TCP/IP不同。UDP是用户数据报协议,是一个面向消息的协议。 一方面,UDP不需要一个长期活动连接,所以建立UDP套接字稍微简单一些。另一方面,UDP消息必须放在一个数据报中。 在IPv4中,数据报包含65507个字节,这些字节信息中还包括首部信息。因为UDP不需要长期的连接,所以它无法得到…

    2023-03-16
    300
  • 二级c语言程序设计题怎么给分_c语言二级试题及答案

    计算机二级考试C语言知识点总结 (完全针对考试大纲) 总体上必须清楚的: 1)程序结构是三种: 顺序结构 , 循环结构(三个循环结构), 选择结构(if 和 switch) 2)读程序都要从main()入口, 然后从最上面顺序往下读(碰到循环做循环,碰到选择做选择)。 3)计算机的数据在电脑中保存是以二进制的形式,数据存放的位置就是他的地址. 4)bit是位…

    2023-03-11
    300
  • grep命令查找文件内容_grep命令的详细使用方法

    Grep 是必不可少的 Linux 和 Unix 命令。它用于搜索给定文件中的文本和字符串。换句话说,grep 命令在给定文件中搜索包含与给定字符串或单词匹配的行。对于开发人员和系统管理员来说,它是 Linux 和类 Unix 系统上最有用的命令之一。让我们看看如何在 Linux 或类 Unix 系统上使用 grep。 教程要求 要求 Linux/Unix/…

    2023-03-08
    2200
  • 脚本是什么意思?计算机

    好几天之前就答应给大家出短视频脚本模版了,但因为手头电脑有些问题,所以耽搁了一段时间。 不过今天,我终于把它们做好啦!!! 这次的模版涵盖了我常拍的4种短视频类型,基本每个类型都给出了案例参考和空白模版,方便大家对比和使用~ 提前声明哈:这次出的脚本模版,是给想拍短视频,但迟迟下不了手的新手用的。因为我自己也是从新手过来的,所以很懂,当我们对某个领域处于完全…

    2023-03-12
    000
  • proe5.0教程 从入门到精通

    本文分享CREO(ProE) 各软件版本、安装教程、视频教程(入门–精通)、学习教程(入门–精通),各取所需,给需要的朋友领取,下载方法见文末! 软件 高级教程 入门–精通 由于资料容量较大,不一一列举。

    2023-03-21
    000
  • 华为win10关闭自动更新方法(怎么设置windows不自动更新)

    目前大多数人所使用的电脑还是Win10系统,但是它有一个让我们非常头疼的问题,就是系统总会自动更新。如果我们不想要自动更新,有什么方法可以帮到我们吗?win10怎么关闭自动更新?那就看看本文的三大方法! 操作环境: 演示机型:Dell optiplex 7050 系统版本:Windows 10 一、Windows设置 我们想要关闭系统的自动更新,win10更…

    2023-03-14
    000

发表回复

登录后才能评论
返回顶部
错说博客上线啦!