mysql用elt和interval来分段查询计算快递收件费

2023-10-10 05:59

本文主要是介绍mysql用elt和interval来分段查询计算快递收件费,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

数据导入

CREATE TABLE `test` (`id` varchar(10) NOT NULL,`件数` int(10) DEFAULT NULL,PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
INSERT into test 
(id,件数)
VALUES
(1,99),
(2,150),
(3,201),
(4,260),
(5,301),
(6,350);

在这里插入图片描述

题目条件

假设一个快递员 收100件及以下 是按1元一件算钱, 101 到 200件 按 0.9元每件算, 依次类推…

那么问题来了, 当我收101件的时候 只能拿到90.9元 还不如 收100件 钱多.

所以老板的算法是这样的:

0 < X <= 100

1元/件

(这个区间最大收益是1*100 = 100元)

100 < X <= 200

如果X * 0.9 小于上个区间的最大值(100), 那么按 100 算.

如果X * 0.9 大于上个区间的最大值(100), 那么按 X*0.9 算.

(这个区间最大收益是0.9*200 = 180元)

200 < X <= 300

如果X * 0.8 小于上个区间的最大值(180), 那么按 180 算.

如果X * 0.8 大于上个区间的最大值(180), 那么按 X * 0.8 算.

(这个区间最大收益是0.8*300=240元)

300 < X

如果X * 0.7 小于上个区间的最大值(240), 那么按 240 算.

如果X * 0.7 大于上个区间的最大值(240), 那么按 X * 0.7 算.

通过件数 求收入
  1. 用case when:
select 件数,
case when 件数 <= 100 then 件数*1
when 件数 >100 and 件数 <=200 and (件数*0.9) < 100 then 100
when 件数 >100 and 件数 <=200 and (件数*0.9) > 100 then 件数*0.9
when 件数 >200 and 件数 <=300 and (件数*0.8) < 180 then 180
when 件数 >200 and 件数 <=300 and (件数*0.8) > 180 then 件数*0.8
when 件数 >300 and (件数*0.7)  < 240 then 240
when 件数 >300 and (件数*0.7)  > 240 then 件数*0.7
end as 收益
from test

在这里插入图片描述
这个方法就完全是按照上面的题目来一步一步设置条件

2. 用elt和interval

select 件数, elt(interval(件数, 100, 112, 200, 226, 300, 343)+1, 1*件数, 100, 0.9*件数, 180, 0.8*件数, 240, 0.7*件数) as 收益
from test

首先介绍一下这两个函数

elt (N,str1,str2,str3,…)
如果N= 1,返回str1,如果N= 2,返回str2,等等。如果N小于1或大于参数个数,返回NULL。

mysql> select ELT(1, ‘a’, ‘b’, ‘c’, ‘d’);

    -> 'a'

mysql> select ELT(4, ‘a’, ‘b’, ‘c’, ‘d’);

    -> 'd'

interval(N,n1,n2,n3,…)
小于后面的某个参数,就返回这个参数的前一个位置数字

如果N < n1返回0,如果n1 <= N < n2返回1,如果n2 < = N < n3返回2 。如果N为NULL,它将返回-1。列表值必须是n1 < n2 < n3的升序形式。

mysql> SELECT INTERVAL(23, 1, 15, 17, 30, 44, 200); (23小于30,30的位置是4,于是返回3)

    -> 3

mysql> SELECT INTERVAL(10, 1, 10, 100, 1000);

    -> 2

mysql> SELECT INTERVAL(22, 23, 30, 44, 200);

    -> 0

回到上面的题:

select 件数, 
elt(interval(件数, 100, 112, 200, 226, 300, 343)+1, 1*件数, 100, 0.9*件数, 180, 0.8*件数, 240, 0.7*件数) as 收益
from test

首先我们计算出 几个临界值, 112, 226, 343, 大于等于这个值, 乘以对应比例就不会比上个区间的最大值小了.

通过elt和interval的结合. 将数据分成
[0-99] , [100-111] , [112-199] , [200-225] , [225-299] , [300-342] , [343以上] 七个段位,

然后 为每个段位匹配一个计算方式.

[1 * 件数] , [100] , [0.9 * 件数 ] , [180] , [ 0.8 * 件数 ] , [240] , [0.7 * 件数]

例如, 当件数等于101时interval()+1, 返回的值是2, 这个只值给elt()函数 得到的结果是第2个计算方式, 是100.

例如, 当件数等于226时interval()+1, 返回的值是5, 这个值传给elt()函数 得到的结果是第5个计算方式, 是0.8*件数.

最终结果:
在这里插入图片描述

这篇关于mysql用elt和interval来分段查询计算快递收件费的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/178434

相关文章

SpringBoot分段处理List集合多线程批量插入数据方式

《SpringBoot分段处理List集合多线程批量插入数据方式》文章介绍如何处理大数据量List批量插入数据库的优化方案:通过拆分List并分配独立线程处理,结合Spring线程池与异步方法提升效率... 目录项目场景解决方案1.实体类2.Mapper3.spring容器注入线程池bejsan对象4.创建

MyBatis分页查询实战案例完整流程

《MyBatis分页查询实战案例完整流程》MyBatis是一个强大的Java持久层框架,支持自定义SQL和高级映射,本案例以员工工资信息管理为例,详细讲解如何在IDEA中使用MyBatis结合Page... 目录1. MyBATis框架简介2. 分页查询原理与应用场景2.1 分页查询的基本原理2.1.1 分

MySQL的JDBC编程详解

《MySQL的JDBC编程详解》:本文主要介绍MySQL的JDBC编程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言一、前置知识1. 引入依赖2. 认识 url二、JDBC 操作流程1. JDBC 的写操作2. JDBC 的读操作总结前言本文介绍了mysq

java.sql.SQLTransientConnectionException连接超时异常原因及解决方案

《java.sql.SQLTransientConnectionException连接超时异常原因及解决方案》:本文主要介绍java.sql.SQLTransientConnectionExcep... 目录一、引言二、异常信息分析三、可能的原因3.1 连接池配置不合理3.2 数据库负载过高3.3 连接泄漏

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

Python实现精确小数计算的完全指南

《Python实现精确小数计算的完全指南》在金融计算、科学实验和工程领域,浮点数精度问题一直是开发者面临的重大挑战,本文将深入解析Python精确小数计算技术体系,感兴趣的小伙伴可以了解一下... 目录引言:小数精度问题的核心挑战一、浮点数精度问题分析1.1 浮点数精度陷阱1.2 浮点数误差来源二、基础解决

MySQL中On duplicate key update的实现示例

《MySQL中Onduplicatekeyupdate的实现示例》ONDUPLICATEKEYUPDATE是一种MySQL的语法,它在插入新数据时,如果遇到唯一键冲突,则会执行更新操作,而不是抛... 目录1/ ON DUPLICATE KEY UPDATE的简介2/ ON DUPLICATE KEY UP

MySQL分库分表的实践示例

《MySQL分库分表的实践示例》MySQL分库分表适用于数据量大或并发压力高的场景,核心技术包括水平/垂直分片和分库,需应对分布式事务、跨库查询等挑战,通过中间件和解决方案实现,最佳实践为合理策略、备... 目录一、分库分表的触发条件1.1 数据量阈值1.2 并发压力二、分库分表的核心技术模块2.1 水平分

Python与MySQL实现数据库实时同步的详细步骤

《Python与MySQL实现数据库实时同步的详细步骤》在日常开发中,数据同步是一项常见的需求,本篇文章将使用Python和MySQL来实现数据库实时同步,我们将围绕数据变更捕获、数据处理和数据写入这... 目录前言摘要概述:数据同步方案1. 基本思路2. mysql Binlog 简介实现步骤与代码示例1

使用shardingsphere实现mysql数据库分片方式

《使用shardingsphere实现mysql数据库分片方式》本文介绍如何使用ShardingSphere-JDBC在SpringBoot中实现MySQL水平分库,涵盖分片策略、路由算法及零侵入配置... 目录一、ShardingSphere 简介1.1 对比1.2 核心概念1.3 Sharding-Sp