开发一套ERP 数据库规整

CREATE DATABASE IF NOT EXISTS ERPCHARACTER SET utf8mb4COLLATE utf8mb4_general_ci;#人工手动判断 告警状态 下订单时自动增加
#通过订单编号区分 交付和未交付的日期和时间USE ERP;CREATE TABLE INBOUND (id_auto INT NOT NULL AUTO_INCREMENT PRIMARY KEY,order_number INT NOT NULL,id INT NOT NULL,name VARCHAR(32),color VARCHAR(32),name_and_color VARCHAR(32),zh_size VARCHAR(32),u_size VARCHAR(32),factory_name VARCHAR(32),input INT,input_date VARCHAR(32)
);CREATE TABLE OUTBOUND(id_auto INT NOT NULL AUTO_INCREMENT PRIMARY KEY,id INT NOT NULL,name VARCHAR(32),color VARCHAR(32),name_and_color VARCHAR(32),zh_size VARCHAR(32),u_size VARCHAR(32),factory_name VARCHAR(32),output INT,output_date VARCHAR(32)
);CREATE TABLE FACTORY (id_auto INT NOT NULL AUTO_INCREMENT PRIMARY KEY,order_number INT NOT NULL,id INT NOT NULL,factory_name VARCHAR(32),brand_name VARCHAR(32),order_counts INT,deliver INT,not_deliver INT,order_date VARCHAR(32)
);CREATE TABLE STORE(id_auto INT NOT NULL AUTO_INCREMENT PRIMARY KEY,id INT NOT NULL,name VARCHAR(32),color VARCHAR(32),name_and_color VARCHAR(32),zh_size VARCHAR(32),u_size VARCHAR(32),store INT,threshold INT,alarm boolean
);CREATE TRIGGER RTC_FACTORYAFTER INSERT ON INBOUND FOR EACH ROW
BEGINUPDATE  FACTORYSET deliver = deliver + NEW.inputWHERE (factory_name = NEW.factory_name) and (order_number = NEW.order_number) and (id = NEW.id);UPDATE FACTORYSET not_deliver = FACTORY.order_counts - FACTORY.deliverWHERE (factory_name = NEW.factory_name) and (order_number = NEW.order_number) and (id = NEW.id);
END;CREATE TRIGGER RTC_STORE_APPENDAFTER INSERT ON INBOUND FOR EACH ROW
BEGINUPDATE STORESET store = store + NEW.inputWHERE (id = NEW.id) and (factory_name = NEW.factory_name);
END;CREATE TRIGGER RTC_STORE_POPAFTER INSERT ON OUTBOUND FOR EACH ROW
BEGINUPDATE STORESET store = store - NEW.outputWHERE (id = NEW.id) and (factory_name = NEW.factory_name);
END;DROP TRIGGER WATCH_INBOUND;CREATE TRIGGER WATCH_INBOUNDAFTER INSERT ON INBOUND FOR EACH ROW
BEGININSERT INTOSTORE(id,name,color,name_and_color,zh_size,u_size,store,threshold,alarm)VALUES(NEW.id,NEW.name,NEW.color,NEW.name_and_color,NEW.zh_size,NEW.u_size,NEW.input,0,FALSE)ON DUPLICATE KEY UPDATEid=NEW.id,name=NEW.name,color=NEW.color,name_and_color=NEW.name_and_color,zh_size=NEW.zh_size,u_size=NEW.u_size,store=NEW.input+store,threshold=0,alarm=FALSE;
END;

大型数据库的维护还挺有意思的

挺有意思的,减少了很多应用层的逻辑,直接在插入时就完成了,数据的操作

所有的数据关联,就可以在数据库中完成操作

开发下来还是底层程序有意思

在让数据关系复杂些,在提高下性能,就会使用类似指针的操作,引用,数据,在来一个临时表

CREATE DATABASE IF NOT EXISTS ERPCHARACTER SET utf8mb4COLLATE utf8mb4_general_ci;USE ERP;CREATE TABLE INBOUND (id_auto INT NOT NULL AUTO_INCREMENT PRIMARY KEY,order_number INT NOT NULL,id INT NOT NULL,name VARCHAR(32),color VARCHAR(32),name_and_color VARCHAR(32),zh_size VARCHAR(32),u_size VARCHAR(32),factory_name VARCHAR(32),input INT,input_date VARCHAR(32)
);CREATE TABLE OUTBOUND(id_auto INT NOT NULL AUTO_INCREMENT PRIMARY KEY,id INT NOT NULL,name VARCHAR(32),color VARCHAR(32),name_and_color VARCHAR(32),zh_size VARCHAR(32),u_size VARCHAR(32),factory_name VARCHAR(32),output INT,output_date VARCHAR(32)
);CREATE TABLE FACTORY (id_auto INT NOT NULL AUTO_INCREMENT PRIMARY KEY,order_number INT NOT NULL,id INT NOT NULL,factory_name VARCHAR(32),brand_name VARCHAR(32),order_counts INT,deliver INT,not_deliver INT,order_date VARCHAR(32)
);CREATE TABLE STORE(id_auto INT NOT NULL AUTO_INCREMENT PRIMARY KEY,id INT NOT NULL,name VARCHAR(32),color VARCHAR(32),name_and_color VARCHAR(32),zh_size VARCHAR(32),u_size VARCHAR(32),store INT,threshold INT,alarm boolean,factory_name VARCHAR(32)
);# DROP TRIGGER RTC_FACTORY;CREATE TRIGGER RTC_FACTORYAFTER INSERT ON INBOUND FOR EACH ROW
BEGINUPDATE  FACTORYSET deliver = deliver + NEW.inputWHERE (factory_name = NEW.factory_name) and (order_number = NEW.order_number) and (id = NEW.id);UPDATE FACTORYSET not_deliver = FACTORY.order_counts - FACTORY.deliverWHERE (factory_name = NEW.factory_name) and (order_number = NEW.order_number) and (id = NEW.id);
END;# DROP TRIGGER RTC_STORE_APPEND;CREATE TRIGGER RTC_STORE_APPENDAFTER INSERT ON INBOUND FOR EACH ROW
BEGINUPDATE STORESET store = store + NEW.inputWHERE (id = NEW.id) and (factory_name = NEW.factory_name);
END;# DROP TRIGGER RTC_STORE_POP;CREATE TRIGGER RTC_STORE_POPAFTER INSERT ON OUTBOUND FOR EACH ROW
BEGINUPDATE STORESET store = store - NEW.outputWHERE id = NEW.id;
END;# DROP TRIGGER WATCH_INBOUND;CREATE TRIGGER WATCH_INBOUNDAFTER INSERT ON INBOUND FOR EACH ROW
BEGININSERT INTOSTORE(id,name,color,name_and_color,zh_size,u_size,store,threshold,alarm)VALUES(NEW.id,NEW.name,NEW.color,NEW.name_and_color,NEW.zh_size,NEW.u_size,NEW.input,0,FALSE)ON DUPLICATE KEY UPDATEid=NEW.id,name=NEW.name,color=NEW.color,name_and_color=NEW.name_and_color,zh_size=NEW.zh_size,u_size=NEW.u_size,store=NEW.input+store,threshold=0,alarm=FALSE;
END;

再加一些’锁’的机制做一下保护才行

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/483188.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【森林生态系统揭秘】用R语言解锁森林结构、功能与稳定性分析!生物多样性与群落组成分析、路径分析、群落稳定性分析等

目录 专题一 理论讲解 专题二 数据获取与处理 专题三 生物多样性与群落组成分析 专题四 机器学习在群落分析中的应用 专题五 路径分析和结构方程模型(SEM) 专题六 群落稳定性分析 专题七 案例分析与写作指南 在生态学研究中,森林生态系…

无分类编址的IPv4地址

/20含义:前20比特位为网络号,后面32-2012为主机号 路由聚合:找共同前缀 所有可分配地址的主机都能接收广播地址,

初始化列表与Static成员

一、再谈构造函数 1.1构造函数体赋值 在创建对象时,编译器会调用构造函数,给对象中各个成员变量一个合适的初始值 class Date { private:int _year;int _month;int _day; public:Date(int year, int month, int day){_year year;_month month;_day …

THENA大涨将对整个DeFi市场产生怎样的影响?

引言 近期,区块链行业的一个热门项目——THENA(THE)代币,在短时间内吸引了大量投资者的目光。THE代币的价格在短短几个月内经历了显著的上涨,引发了市场对其背后机制的浓厚兴趣。而在THENA生态系统的成功背后&#xf…

从被动响应到主动帮助,ProActive Agent开启人机交互新篇章

在人工智能领域,我们正见证着一场革命性的变革。传统的AI助手,如ChatGPT,需要明确的指令才能执行任务。但现在,清华大学联合面壁智能等团队提出了一种全新的主动式Agent交互范式——ProActive Agent,它能够主动观察环境…

SpringBoot(一)

Springboot(一) 什么是SpringBoot SpringBoot是Spring项目中的一个子工程,与Spring-famework同属于Spring的产品 用一些固定的方式来构建生产级别的Spring应用。SpringBoot推崇约定大于配置的方式以便于能够尽可能快速的启动并运行程序 我们把Spring Boot称为搭建程…

PDF与PDF/A的区别及如何使用Python实现它们之间的相互转换

目录 概述 PDF/A 是什么?与 PDF 有何不同? 用于实现 PDF 与 PDF/A 相互转换的 Python 库 Python 实现 PDF 转 PDF/A 将 PDF 转换为 PDF/A-1a 将 PDF 转换为 PDF/A-1b 将 PDF 转换为 PDF/A-2a 将 PDF 转换为 PDF/A-2b 将 PDF 转换为 PDF/A-3a 将…

【设计模式系列】备忘录模式(十九)

目录 一、什么是备忘录模式 二、备忘录模式的角色 三、备忘录模式的典型应用场景 四、备忘录模式在Calendar中的应用 一、什么是备忘录模式 备忘录模式(Memento Pattern)是一种行为型设计模式,它允许在不暴露对象内部状态的情况下保存和恢…

window 下用Ollama 开发一个简单文档问答系统

文档问答系统 本系统利用先进的语言模型和检索技术,为用户提供基于上传文件内容的问答服务。支持多种文件格式,包括 Word、PDF、CSV、SQL 和 TXT 文件。 功能介绍 文件上传 用户可以同时上传多个文件。支持的文件类型包括:.doc, .docx, .…

全国296个地级市平均房价数据(2000-2022年)

全国296个地级市平均房价数据(2000-2022年),包括面板数据和截面数据 点击下载 1、数据来源:安居客、房天下、房价行情网等住房交易网页整理 2、时间跨度:2000-2022年 3、区域范围:全国296个地级市 4、缺失说明:西…

贴片式内存卡 ​SD NAND​

SD NAND FLASH 贴片式SD卡 贴片式t卡 存储芯片 1. 什么是贴片式内存卡 贴片式内存卡是指一种将内存芯片直接贴装在电路板上的内存卡类型。与传统的插针式内存卡(如SD卡、MicroSD卡)不同,贴片式内存卡通常不具有外部引脚或接口,而…

C—操作符易错点

strlen与sizeof strlen求的是大小,包含“\0” strlen求的是,长度不包括“\0” 注意:空格也算一个字符 操作符“/”(除法) 对于除法操作符来说,两边都是整数,那么就是整数除法 如果想计算出小数&#x…

基于PyTorch框架的线性回归实现指南

目录 ​编辑 1. 线性回归基础 2. PyTorch环境搭建 3. 数据准备 4. 定义线性回归模型 5. 损失函数和优化器 6. 训练模型 7. 评估模型 8. 结论 线性回归是统计学和机器学习中最基本的预测模型之一,它试图找到输入特征和输出结果之间的线性关系。在深度学习框…

R语言机器学习论文(六):总结

文章目录 介绍参考文献介绍 本文采用R语言对来自进行数据描述、数据预处理、特征筛选和模型构建。 最后我们获得了一个能有效区分乳腺组织的随机森林预测模型,它的性能非常好,这意味着它可能拥有非常好的临床价值。 在本文中,我们利用R语言对来自美国加州大学欧文分校的B…

基于Java Springboot校园导航微信小程序

一、作品包含 源码数据库设计文档万字PPT全套环境和工具资源部署教程 二、项目技术 前端技术:Html、Css、Js、Vue、Element-ui 数据库:MySQL 后端技术:Java、Spring Boot、MyBatis 三、运行环境 开发工具:IDEA/eclipse微信开发…

面试题-RocketMQ的基本架构、支持的消息模式、如何保证消息的可靠传输

相关问题 1、RocketMQ的基本架构是怎样的?请简述各组件的作用。 2、RocketMQ支持哪几种消息模式(如点对点、发布/订阅)?请简要说明它们的区别。 3、如何使用Java客户端实现一个简单的消息生产者和消费者? 4、RocketMQ…

WPF+LibVLC开发播放器-LibVLC在C#中的使用

使用WPFLibVLC快速 开发一个播放器 安装包Nuget 安装下面两个包,必须安装两个 一个是相关框架对应的包,Winform就安装LibVLCSharp.Winform;WPF就安装LibVLCSharp.WPF,以此类推,他们都默认依赖LibVLCSharp,不需要例外安装 一个是…

CSS变量用法及实践

目录 一、基本用法 1.1、定义变量 1.2、使用变量 1.3 、修改变量的值 二、命名规范 2.1、使用有意义的名称 2.2、使用命名空间 三、变量值类型 3.1、如果变量值是一个字符串,可以与其他字符串拼接,例如: 3.2、 如果变量值是数值&a…

WEB开发: 丢掉包袱,拥抱ASP.NET CORE!

今天的 Web 开发可以说进入了一个全新的时代,前后端分离、云原生、微服务等等一系列现代技术架构应运而生。在这个背景下,作为开发者,你一定希望找到一个高效、灵活、易于扩展且具有良好性能的框架。那么,ASP.NET Core 显然是一个…

【汇编语言】标志寄存器(一) —— 标志寄存器中的标志位:ZF、PF、SF、CF、OF 一网打尽

前言 📌 汇编语言是很多相关课程(如数据结构、操作系统、微机原理)的重要基础。但仅仅从课程的角度出发就太片面了,其实学习汇编语言可以深入理解计算机底层工作原理,提升代码效率,尤其在嵌入式系统和性能优…