未完工数据和系统数据对比分析

2024-06-21 02:52

本文主要是介绍未完工数据和系统数据对比分析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

select

*

FROM

(

select

a.`db_close_systime` AS a_db_close_systime, -- 订单关闭时间

u.`db_close_systime` AS u_db_close_systime, -- 订单关闭时间

COALESCE( u.`db_close_systime`,a.`db_close_systime`) AS db_close_systime_coalesced ,-- 取非空值的订单关闭时间

a.`inv_code` AS a_inv_code, -- 存货编码

u.`inv_code` AS u_inv_code, -- 存货编码

a.`inv_so_type1` AS a_inv_so_type1, -- 销售一级归类

u.`inv_so_type1` AS u_inv_so_type1, -- 销售一级归类

CASE WHEN a.inv_so_type1 <> u.inv_so_type1 THEN 'Different' ELSE 'Same' END AS inv_so_type1_difference,

a.`order_type` AS a_order_type, -- 销售订单状态

u.`order_type` AS u_order_type, -- 销售订单状态

COALESCE(u.`order_type`, a.`order_type`) AS order_type_coalesced,

a.`so_code_row` AS a_so_code_row, -- 销售子订单编号

u.`so_code_row` AS u_so_code_row, -- 销售子订单编号

a.`so_code` AS a_so_code, -- 销售订单编号

u.`so_code` AS u_so_code, -- 销售订单编号

a.`so_region` AS a_so_region, -- 销售区域

u.`so_region` AS u_so_region, -- 销售区域

CASE

WHEN a.so_region <> u.so_region THEN 'Different'

ELSE 'Same'

END AS region_difference,

a.so_num AS a_so_num,

u.so_num AS u_so_num,

CASE WHEN a.so_num <> u.so_num THEN 'Different' ELSE 'Same' END AS so_num_difference,

a.unfinished_num AS a_unfinished_num, -- 未完工数量

u.unfinished_num AS u_unfinished_num,

CASE WHEN a.unfinished_num <> u.unfinished_num THEN 'Different' ELSE 'Same' END AS unfinished_num_difference,

a.unsold_num AS a_unsold_num,-- 未投单存货数量

u.unsold_num AS u_unsold_num,

CASE WHEN a.unsold_num <> u.unsold_num THEN 'Different' ELSE 'Same' END AS unsold_num_difference,

a.in_num AS a_in_num,-- 累计入库存货数量

u.in_num AS u_in_num,

CASE WHEN a.in_num <> u.in_num THEN 'Different' ELSE 'Same' END AS in_num_difference,

a.in_process AS a_in_process, -- 在制数量

u.in_process AS u_in_process,

CASE WHEN a.in_process <> u.in_process THEN 'Different' ELSE 'Same' END AS in_process_difference,

a.verify_date AS a_verify_date,

u.verify_date AS u_verify_date,

CASE WHEN a.verify_date <> u.verify_date THEN 'Different' ELSE 'Same' END AS verify_date_difference

from

(

SELECT

o.so_code, -- 销售订单号

o.so_code_row,-- 销售子订单号

o.so_region, -- 销售区域

o.pre_month_bt, -- 要货月份

o.verify_date, -- 审核日期

o.st_code, -- 销售类型编码

o.st_name, -- 销售类型名称

o.region, -- 大区

o.order_date, -- 单据日期

o.pre_date, -- 预发货日期

o.inv_so_type1, -- 销售一级归类

o.cus_code, -- 客户编码

o.cus_name, -- 客户名称

o.project, --项目

o.inv_code, -- 存货编码

o.inv_name, -- 存货名称

o.inv_std, -- 产品规格

SUM(COALESCE(o.quantity, 0)) AS so_num, -- 销售订单存货数量

SUM(COALESCE(o.quantity, 0)) - SUM(COALESCE(r.in_num, 0)) AS unfinished_num, -- 未完工数量

SUM(COALESCE(m.in_process, 0)) AS in_process, -- 在制数量

SUM(COALESCE(o.quantity, 0)) - SUM(COALESCE(r.in_num, 0)) - SUM(COALESCE(m.in_process, 0)) AS unsold_num, -- 未投单存货数量

SUM(COALESCE(r.in_num, 0)) AS in_num , -- 累计入库存货数量

case when o.define23 is null and o.db_close_systime is null then '正常'

when o.define23 is null and o.db_close_systime is not null then '异常' else o.define23 end as order_type,

o.db_close_systime,

'2024-06-17' as dt

FROM

(select * from warehouse.dwd_sa_order_details_df where dt = '2024-06-17' and inv_code LIKE '3%'

-- ,'订单取消'

-- 不要备料,取'2022-06-01',不要库存发货

and st_code not in ('10') and substr(cast(verify_date as string),1,10) > '2022-06-01'

and substr(cast(so_code as string),1,2) <> 'BL'

)o

LEFT JOIN

(select so_code,inv_code,so_seq,sum(in_qty) as in_num from warehouse.dwd_wh_inv_in_df

where dt='2024-06-17'

and inv_code like '3%'

and mo_code NOT LIKE '%CX%'

AND mo_code NOT LIKE '%FG%'

group by so_code,inv_code ,so_seq

)r

ON cast(o.so_code as string)=cast(r.so_code as string) and o.inv_code = r.inv_code and so_seq = row_no

left join

(select so_order_detail_id,inv_code,sum(incomplete_num) AS in_process

from warehouse.dwd_pro_order_details_df

where dt = '2024-06-17' and status = 3 and inv_code LIKE '3%'

group by

so_order_detail_id,inv_code

)m

on cast(o.auto_id as string) = cast(m.so_order_detail_id as string) and o.inv_code = m.inv_code

-- where o.db_close_systime is null or o.define23 like '临时失效'

-- OR r.in_num is not null

group by

o.so_code, -- 销售订单号

o.so_code_row,-- 销售子订单号

o.so_region, -- 销售区域

o.pre_month_bt, -- 要货月份

o.verify_date, -- 审核日期

o.st_code, -- 销售类型编码

o.st_name, -- 销售类型名称

o.region, -- 大区

o.order_date, -- 单据日期

o.pre_date, -- 预发货日期

o.inv_so_type1, -- 销售一级归类

o.cus_code, -- 客户编码

o.cus_name, -- 客户名称

o.project, --项目

o.inv_code, -- 存货编码

o.inv_name, -- 存货名称

o.define23 ,

o.db_close_systime,

o.inv_std -- 产品规格

)a

left join warehouse.dws_sa_unfinished_order_amend_df u

on a.so_code_row = u.so_code_row

-- where a.db_close_systime is null and

-- a.unfinished_num >0 and a.so_code is not null and a.so_code_row is not null and a.inv_code is not null

where u.unfinished_num >0 and u.so_code is not null and u.so_code_row is not null and u.inv_code is not null

)T

where T.a_unfinished_num >0 and T.order_type_coalesced = '正常'

and u_order_type is not null

select

distinct verify_state

from warehouse.dwd_sa_order_details_df

这篇关于未完工数据和系统数据对比分析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

SQL Server修改数据库名及物理数据文件名操作步骤

《SQLServer修改数据库名及物理数据文件名操作步骤》在SQLServer中重命名数据库是一个常见的操作,但需要确保用户具有足够的权限来执行此操作,:本文主要介绍SQLServer修改数据... 目录一、背景介绍二、操作步骤2.1 设置为单用户模式(断开连接)2.2 修改数据库名称2.3 查找逻辑文件名

canal实现mysql数据同步的详细过程

《canal实现mysql数据同步的详细过程》:本文主要介绍canal实现mysql数据同步的详细过程,本文通过实例图文相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的... 目录1、canal下载2、mysql同步用户创建和授权3、canal admin安装和启动4、canal

MyBatis Plus 中 update_time 字段自动填充失效的原因分析及解决方案(最新整理)

《MyBatisPlus中update_time字段自动填充失效的原因分析及解决方案(最新整理)》在使用MyBatisPlus时,通常我们会在数据库表中设置create_time和update... 目录前言一、问题现象二、原因分析三、总结:常见原因与解决方法对照表四、推荐写法前言在使用 MyBATis

Python主动抛出异常的各种用法和场景分析

《Python主动抛出异常的各种用法和场景分析》在Python中,我们不仅可以捕获和处理异常,还可以主动抛出异常,也就是以类的方式自定义错误的类型和提示信息,这在编程中非常有用,下面我将详细解释主动抛... 目录一、为什么要主动抛出异常?二、基本语法:raise关键字基本示例三、raise的多种用法1. 抛

使用SpringBoot整合Sharding Sphere实现数据脱敏的示例

《使用SpringBoot整合ShardingSphere实现数据脱敏的示例》ApacheShardingSphere数据脱敏模块,通过SQL拦截与改写实现敏感信息加密存储,解决手动处理繁琐及系统改... 目录痛点一:痛点二:脱敏配置Quick Start——Spring 显示配置:1.引入依赖2.创建脱敏

基于Python实现一个简单的题库与在线考试系统

《基于Python实现一个简单的题库与在线考试系统》在当今信息化教育时代,在线学习与考试系统已成为教育技术领域的重要组成部分,本文就来介绍一下如何使用Python和PyQt5框架开发一个名为白泽题库系... 目录概述功能特点界面展示系统架构设计类结构图Excel题库填写格式模板题库题目填写格式表核心数据结构

github打不开的问题分析及解决

《github打不开的问题分析及解决》:本文主要介绍github打不开的问题分析及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、找到github.com域名解析的ip地址二、找到github.global.ssl.fastly.net网址解析的ip地址三

Linux系统中的firewall-offline-cmd详解(收藏版)

《Linux系统中的firewall-offline-cmd详解(收藏版)》firewall-offline-cmd是firewalld的一个命令行工具,专门设计用于在没有运行firewalld服务的... 目录主要用途基本语法选项1. 状态管理2. 区域管理3. 服务管理4. 端口管理5. ICMP 阻断

Mysql的主从同步/复制的原理分析

《Mysql的主从同步/复制的原理分析》:本文主要介绍Mysql的主从同步/复制的原理分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录为什么要主从同步?mysql主从同步架构有哪些?Mysql主从复制的原理/整体流程级联复制架构为什么好?Mysql主从复制注意

详解如何使用Python构建从数据到文档的自动化工作流

《详解如何使用Python构建从数据到文档的自动化工作流》这篇文章将通过真实工作场景拆解,为大家展示如何用Python构建自动化工作流,让工具代替人力完成这些数字苦力活,感兴趣的小伙伴可以跟随小编一起... 目录一、Excel处理:从数据搬运工到智能分析师二、PDF处理:文档工厂的智能生产线三、邮件自动化: