Java全栈开发---Java ERP系统开发:商业ERP(十一)库存预警,JavaMail发送预警邮件

《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门,即可获取!

将整个查结果拆分成2个子查询,再合并起来

在这里插入图片描述

(3)SQL语句编写

这种带子查询的语句相对复杂,我们分步来实现

1)先实现当前商品库存统计,查询出每种商品的库存数量

在这里插入图片描述

这种结果只能查询存在库存的商品数量,而库存中不存在的商品侧不会显示出来。我们可以通过左外链接的方式进行查询。使用nvi方法把null转换0

在这里插入图片描述

2)实现销售订单中商品的统计,统计每种待发货的商品数量

在这里插入图片描述

3)通过商品编号将上面这2种查询组合起来

在这里插入图片描述

(4)视图创建

我们上边的语句查询的结果是我们经常要用到的,每次都写的很繁琐,所以我们可以把常用的复杂的查询直接建立视图,把它当成hibernate中的一个表来处理,这样可以极简化我们的开发,便于日常维护。

创建视图SQL语句

在这里插入图片描述

2、代码编写
(1)创建实体类Storealert

package com.itzheng.erp.entity;

public class Storealert {

private Long uuid;

private String name;

private Long storenum;

private Long outnum;

public Long getUuid() {

return uuid;

}

public void setUuid(Long uuid) {

this.uuid = uuid;

}

public String getName() {

return name;

}

public void setName(String name) {

this.name = name;

}

public Long getStorenum() {

return storenum;

}

public void setStorenum(Long storenum) {

this.storenum = storenum;

}

public Long getOutnum() {

return outnum;

}

public void setOutnum(Long outnum) {

this.outnum = outnum;

}

@Override

public String toString() {

return “Storealert [uuid=” + uuid + “, name=” + name + “, storenum=” + storenum + “, outnum=” + outnum + “]”;

}

}

(2)创建映射文件

映射文件:storealert.hbm.xml

在这里插入图片描述

(3)数据访问层实现

在IStoredetailDao和StoredetailDao中加入方法与实践

1)IStoredetailDao

在这里插入图片描述

2)IStoredetailDao

在这里插入图片描述

(4)业务逻辑层实现

在IStoredetailBiz和StoredetailBiz中添加方法与实现

在这里插入图片描述

在这里插入图片描述

(5)Action层的实现

在StoredetailAction中加入方法:

在这里插入图片描述

(6)页面代码

1)添加js/storealert.js

在这里插入图片描述

2)添加storealert.html文件

在这里插入图片描述

3)运行结果

http://localhost:8080/erp/storealert.html

在这里插入图片描述

二、JavaMail发送预警邮件(扩展)


1、需求分析

实现发送邮件预警功能,根据相关人员进行采购,点击“发送警报邮件”按钮即可发送库存报警

如果存在报警商品并成功发送 ,提示发送成功

如果不存在报警商品,提示没有库存报警商品

在这里插入图片描述

2、JavaMail介绍

JavaMail,顾名思义,提供给开发者处理电子邮件相关的编程接口。它是Sun发布的用来处理email的API。它可以方便地执行一些常用的邮件传输。JavaMail API是Sun公司为方便Java开发人员在应用程序中实现邮件发送和接收功能而提供的一套标准开发包,它支持一些常用的邮件协议,如:SMTP、POP3、IMAP。开发人员使用JavaMail API编写邮件处理软件时,无须考虑邮件协议底层的实现细节,只要调用JavaMail开发包中相应的API类就可以了。

使用 JavaMail,我们可以实现类似 OutLook、FoxMail 的软件

Spring的javaMailSender对JavaMail进行封装,简化了开发,告别繁琐的API

3、ERP中实现发送预警邮件
(1)添加依赖

在父工程的pom.xml中添加java mail的依赖

在这里插入图片描述

(2)编写发送邮件的工具类

在业务逻辑层当中创建MailUtil

在这里插入图片描述

(3)编写spring配置文件

创建applicationContext_mail.xml

在这里插入图片描述

<?xml version="1.0" encoding="UTF-8"?>

<beans xmlns=“http://www.springframework.org/schema/beans”

xmlns:xsi=“http://www.w3.org/2001/XMLSchema-instance” xmlns:context=“http://www.springframework.org/schema/context”

xmlns:aop=“http://www.springframework.org/schema/aop” xmlns:tx=“http://www.springframework.org/schema/tx”

xsi:schemaLocation="

http://www.springframework.org/schema/beans

http://www.springframework.org/schema/beans/spring-beans.xsd

http://www.springframework.org/schema/context

http://www.springframework.org/schema/context/spring-context.xsd

http://www.springframework.org/schema/tx

http://www.springframework.org/schema/tx/spring-tx.xsd

http://www.springframework.org/schema/aop

http://www.springframework.org/schema/aop/spring-aop.xsd

">

true

true

(4)编写业务逻辑类

给IStoredetailBiz和StoredetailBiz添加sendStoreAlertMail方法

IStoredetailBiz

在这里插入图片描述

StoredetailBiz

在这里插入图片描述

private MailUtil mailUtil;

public void setMailUtil(MailUtil mailUtil) {

this.mailUtil = mailUtil;

}

private String toAddress;// 收件箱

private String subject;// 主题

private String text;// 正文

public void setToAddress(String toAddress) {

this.toAddress = toAddress;

}

public void setSubject(String subject) {

this.subject = subject;

}

public void setText(String text) {

this.text = text;

}

/**

  • 发送库存预警邮件

  • @throws MessagingException

*/

public void sendStoreAlertMail() throws MessagingException {

// 得到库存预警列表

List storeAlertList = storedetailDao.getStorealertList();

if (storeAlertList.size() > 0) {

mailUtil.sendMail(toAddress,

subject.replace(“[time]”, new SimpleDateFormat(“yyyy-MM-dd hh:mm:ss”).format(new Date())),

text.replace(“[count]”, String.valueOf(storeAlertList.size())));

} else {

throw new ErpException(“没有库存预警信息”);

}

}

(5)修改applicationContext_biz.xml

storedeatilBiz节点,添加

最后

由于细节内容实在太多了,为了不影响文章的观赏性,只截出了一部分知识点大致的介绍一下,每个小节点里面都有更细化的内容!

小编准备了一份Java进阶学习路线图(Xmind)以及来年金三银四必备的一份《Java面试必备指南》

《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门,即可获取!

throw new ErpException(“没有库存预警信息”);

}

}

(5)修改applicationContext_biz.xml

storedeatilBiz节点,添加

最后

由于细节内容实在太多了,为了不影响文章的观赏性,只截出了一部分知识点大致的介绍一下,每个小节点里面都有更细化的内容!

[外链图片转存中…(img-XNUrs9Ey-1714678897794)]

小编准备了一份Java进阶学习路线图(Xmind)以及来年金三银四必备的一份《Java面试必备指南》

[外链图片转存中…(img-uROt2WQj-1714678897794)]

《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门,即可获取!

  • 7
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值