SQL数据库根据需求发送邮件

news2024/9/20 6:27:24

一、启用数据库邮件

手动启用数据库邮件功能,需执行以下脚本:

exec sp_configure 'show advanced options',1
RECONFIGURE

exec sp_configure 'Database Mail XPs',1
RECONFIGURE With Override

二、邮件服务器设置

1.邮箱启用设置-POP3/IMAP/SMTP/Exchange/CardDAV/CalDAV服务,开启时有提示有授权码,记录下,后面配置需要录入

登录QQ邮箱——账户——相关设置开启即可。

其他步骤参考其他文献。

三、数据库实现操作步骤(定时作业,触发器都可以)

----1、取出异常单号,且状态不等于处理结束 SELECT * FROM dbo.ProductionExceptionManagement----

----2、根据异常单号找到最新当前节点的创建时间  SELECT * FROM dbo.ProductionExceptionHandle

----3、定时作业获取当前系统时间与最新当前节点时间进行比对

----4、如果最新异常单号的创建时间与当前定时作业获取的系统时间之差大于30分钟

----5、给指定人员发送邮件------
DECLARE @ExceptionStatusId CHAR(12)='',
        @ProductionExceptionManagementId  CHAR (12),
        @CreateDate  DATETIME='',
        @SystemDate DATETIME='',
        @SDate DATETIME='',
        @EDate DATETIME='',
        @ExceptionLocationId CHAR (12)='',
        @Overtime NVARCHAR(50)='',
        @Nextmiaoshu NVARCHAR(100)='',
        @ZWEN NVARCHAR(MAX) =''
        --------定义游标--
        DECLARE Pemid_CURSOR CURSOR LOCAL
        FOR
        SELECT ProductionExceptionManagementId FROM dbo.ProductionExceptionManagement WHERE ExceptionStatusId<>'筛选条件' 
        --AND CreateDate BETWEEN @SDate and @EDate 
        FOR READ ONLY
        OPEN Pemid_CURSOR
        FETCH NEXT FROM Pemid_CURSOR
        INTO @ProductionExceptionManagementId
        WHILE @@FETCH_STATUS=0
        BEGIN

        --SET @ExceptionLocationId='1'
         --SELECT 
   --      @ExceptionLocationId = ExceptionLocationId 
   --                         FROM ExceptionLocation Ex LEFT OUTER JOIN  dbo.ProductionExceptionManagement Pd ON Ex.FactoryId=pd.FactoryId AND Ex.SiteId=Pd.SiteId
   --                         AND EX.WorkcenterId=Pd.WorkcenterId WHERE Ex.ExceptionTypeId=Pd.ExceptionTypeId 

        SET @ExceptionStatusId=(SELECT TOP 1 StatusId  FROM dbo.ProductionExceptionHandle WHERE ProductionExceptionManagementId=@ProductionExceptionManagementId ORDER BY CreateDate desc)

        SET @CreateDate=(SELECT TOP 1 HandleTime FROM dbo.ProductionExceptionHandle WHERE ProductionExceptionManagementId=@ProductionExceptionManagementId ORDER BY CreateDate desc)

        --SET @Nextmiaoshu=(SELECT BillStatesDescription FROM dbo.BillStates WHERE BillStatesId=@ExceptionStatusId)
        SET @Nextmiaoshu='等待|故障诊断'

        SET @ZWEN=@Nextmiaoshu+'超时30分钟未处理'+@ProductionExceptionManagementId

        SET @SystemDate=GETDATE()

        SET  @Overtime=(SELECT DATEDIFF(MINUTE,@CreateDate,@SystemDate))

        IF @Overtime>30
        BEGIN
        DECLARE @mailitem_id INT;
        EXEC msdb.dbo.sp_send_dbmail @profile_name = 'mini',                -- 配置文件名
                                     @recipients = '邮箱地址1;邮箱地址2;邮箱地址3', -- 收件箱email地址-- varchar(max)
                                     --@copy_recipients = '',  -- varchar(max)
                                     --@blind_copy_recipients = '',         -- varchar(max)
                                     @subject = N'故障报单超时未处理',       -- 邮件主题-- nvarchar(255)
                                     @body = @ZWEN                        -- 邮件正文nvarchar(max)
                                     --@body_format = ''                   -- varchar(20)
                                     --@importance = '1',                    -- varchar(6)
                                     --@sensitivity = '1',                   -- varchar(12)
                                     --@file_attachments = N'1',             -- 用于发送附件填写路径nvarchar(max)
                                     --@query = N'1',                        -- 执行有效SQL语句nvarchar(max)
                                     --@execute_query_database = 'PLC',      -- sysname
                                     --@attach_query_result_as_file = 1, -- 把 @query 的执行语句所返回消息写入.doc bit
                                     --@query_attachment_filename = N'1',    -- 设置附件文件的名称和类型为doc文档,如是文本则是.txt格式nvarchar(260)
                                     --@query_result_header = 1,         -- bit
                                     --@query_result_width = 0,             -- int
                                     --@query_result_separator = '1' ,       -- char(1)
                                     --@exclude_query_output = 1,        -- bit
                                     --@append_query_error = 1,          -- bit
                                     --@query_no_truncate = 1,           -- bit
                                     --@query_result_no_padding = 1,     -- bit
                                     --@mailitem_id = @mailitem_id OUTPUT,  -- int
                                     --@from_address = '21',                  -- varchar(max)
                                     --@reply_to = '21'                       -- varchar(max)
        
        END
      --进入下一行数据--
            
        FETCH NEXT FROM PemID_cursor
        INTO @ProductionExceptionManagementId
             
        END
        ---关闭游标--------------
        CLOSE PemID_cursor
        ---释放游标------------------
        DEALLOCATE PemID_cursor

验证结果:

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

DAMA数据管理知识体系指南之数据质量管理

第12章 数据质量管理 12.1 简介 数据质量管理是组织变革管理中一项关键的支撑流程。业务重点的变化、公司的业务整合战略&#xff0c;以及并购与合作&#xff0c;都对IT职能提出了更高要求&#xff0c;包括整合数据源、创建一致的数据副本、交互提供数据或整合数据。与遗留系…

SpringAOP理解实现方式

Aop 什么是Aop&#xff1f; AOP就是面向切面编程&#xff0c;通过预编译方式以及运行期间的动态代理技术来实现程序的统一维护功能。 什么是切面&#xff0c;我理解的切面就是两个方法之间&#xff0c;两个对象之间&#xff0c;两个模块之间就是一个切面。假设在两个模块之间…

9.手动部署Java应用

Jenkins部署Java应用什么java应用手动部署java环境、手动进行代码发布过程1.环境准备配制负载均衡配制webserver&#xff08;tomcat&#xff09;集群本地做域名劫持查看效果2.模拟开发提交Java代码-->推送至gitlab上传代码至gitlab3.运维克隆代码&#xff0c;然后通过maven手…

Yolo-fastestv2训练自己的数据集记录

Yolo-fastestv2训练自己的数据集记录 第一节&#xff1a;代码来源 本机环境&#xff1a;ubuntu20&#xff0c;cuda,cudnn,pytorch1.11.0 代码来源&#xff1a;https://github.com/dog-qiuqiu/Yolo-FastestV2 配置环境后先测试一下环境 终端输入&#xff1a; python3 test.py…

Vue入门介绍

一、背景 目前前端主流框架有Vue、react、Angular等&#xff0c;其中Vue简单易学&#xff0c;只要稍微会点HTML、CSS、JavaScript基础就能很快上手Vue&#xff0c;其门槛低&#xff0c;上手速度快的特点&#xff0c;深受测试开发同学喜爱&#xff0c;已逐渐成为测开必备的前端…

spring回显方式在代码层面的复现(内存马系列篇十四)

前言 在前面的一章中&#xff0c;主要在理论上进行了各种内存马的实现&#xff0c;这里就做为上一篇的补充&#xff0c;自己搭建反序列化的漏洞环境来进行上文中理论上内存马的注入实践。 这是内存马系列文章的第十四篇。 环境搭建 可以使用我用的漏洞环境 https://github…

一款基于java的超级棒的开源支付系统(用来毕设也不错),国内首款开源的互联网支付系统

最近就快要到年末了&#xff0c;小编想着应该会有很多公司开始冲年度的业绩了&#xff0c;既然是冲业绩&#xff0c;就离不开我们的支付系统&#xff0c;所以小编就去网上给大家找到了一款超级棒的开源支付系统&#xff01;帮助大家从头到尾了解清楚这其中的逻辑&#xff01;所…

蓝牙 - 芯片制造商的代号编制以及在Windows上查看

在蓝牙技术的规范中&#xff0c;对很多信息都进行了整理和代号分配&#xff0c;比如生产蓝牙芯片的厂商&#xff0c;也进行了数字编号。 有一个专门的“Assigned Numbers”的PDF文档&#xff0c;记录了蓝牙规范中的各种类型数字所表示的含义。 本文介绍的数字类型&#xff0c…

JavaScript Window - 浏览器对象模型

JavaScript Window - 浏览器对象模型 浏览器对象模型 (BOM) BOM&#xff1a;Browser Object Model 是浏览器对象模型&#xff0c;BOM由多个对象构成&#xff0c;其中代表浏览器窗口的window对象是BOM的顶层对象也是核心对象&#xff0c;其他对象都是该对象的子对象。 BOM对象…

IB-PYP幼儿十大素质培养目标

作为IB候选学校&#xff0c;一直秉承IB教育的核心目标&#xff0c;贯彻在幼儿的学习生活中。IB教育之所以成为当今国际教育的领跑者&#xff0c;最主要的原因是IB教育是切切实实的“全人”教育&#xff0c;“素质”教育&#xff0c;拥有一套完整的教学服务体系。当我们走进IB“…

【机器学习实战】七、梯度下降

梯度下降 一、线性回归 线性回归算法推导过程可以基于最小二乘法直接求解&#xff0c;但这并不是机器学习的思想&#xff0c;由此引入了梯度下降方法。本文讲解其中每一步流程与实验对比分析。 1.初始化 import numpy as np import os %matplotlib inline import matplotli…

C语言(结构和指针)

目录 1.声明结构指针 2.用指针访问成员 3.传递结构成员 4.传递结构的地址 5.传递结构 6.机构的其他特性 7.结构中的字符数组和字符指针 关于为什么要使用指向结构的指针。 第一&#xff0c;就像指向数组的指针比数组本身更容易操作一样&#xff0c;指向结构的指针通常比…

5年自动化测试,终于进字节了,年薪30w其实也并非触不可及

我的职业生涯开始和大多数测试人一样&#xff0c;开始接触都是纯功能界面测试&#xff0c;第一份测试工作就是在电商公司做功能测试&#xff0c;工作忙忙碌碌&#xff0c;每天在各种业务需求学习和点点中度过&#xff0c;过了好几年发现自己还只是一个功能测试工程师&#xff0…

第十二章 Ambari二次开发之集成Alluxio

1、Alluxio高可用部署 生产环境&#xff1a;使用具有高可用性的模式来运行Alluxio masters。 1.1、Alluxio架构 ​ Alluxio可以被分为三个部分&#xff1a;**masters、workers以及clients。**一个典型的设置由一个主服务器、多个备用服务器和多个worker组成。客户端用于通过S…

机器学习实战--梯度下降法进行波士顿房价预测

前言&#xff1a; Hello大家好&#xff0c;我是Dream。 今天来学习一下如何使用机器学习梯度下降法进行波士顿房价预测&#xff0c;这是简单的一个demo&#xff0c;主要展示的是一些小小的思路~ 本文目录&#xff1a;一、波士顿房价预测1.全部的数据可视化2.地理数据可视化3.房…

基于”PLUS模型+“生态系统服务多情景模拟预测实践

工业革命以来&#xff0c;社会生产力迅速提高&#xff0c;人类活动频繁&#xff0c;此外人口与日俱增对土地的需求与改造更加强烈&#xff0c;人-地关系日益紧张。此外&#xff0c;土地资源的不合理开发利用更是造成了水土流失、植被退化、水资源短缺、区域气候变化、生物多样性…

根据手机号显示其运营商信息phone.find

【小白从小学Python、C、Java】【计算机等级考试500强双证书】【Python-数据分析】根据手机号显示其运营商信息phone.find选择题以下关于python代码表述错误的一项是?from phone import PhonephonePhone()print(【执行】phone.find())resultphone.find("13366667777"…

21.操作符优先级和结合性列表,复杂表达式求值顺序

目录一、复杂表达式求值顺序1.操作符的优先级2.操作符的结合性3.操作符是否控制执行的顺序二、求值顺序三、操作符优先级和结合性列表一、复杂表达式求值顺序 复杂表达式的求值顺序由三个因素决定&#xff1a; 1.操作符的优先级 2.操作符的结合性 3.操作符是否控制执行的顺序 1…

【代码随想录训练营】【Day12休息】【Day13】第五章|栈与队列|239. 滑动窗口最大值|347.前 K 个高频元素|总结

239.滑动窗口最大值 题目详细&#xff1a;LeetCode.239 看到滑动窗口&#xff0c;我立马想起了双指针&#xff0c;利用双指针可以非常清晰地理解解题思路&#xff1a; 定义一个变量 max_i 用于记录窗口中的最大值的索引每次窗口滑动后 如果出去的值是最大值&#xff0c;那么…

ChatGPT实火,这小东西牛在哪?

ChatGPT&#xff0c;真的火了啊&#xff01; 相信许多朋友都听说过 ChatGPT铺天盖地的赞美&#xff0c;但并不清楚它是个啥。 体制内让ChatGPT写材料&#xff0c;广告行业让ChatGPT写策划案&#xff0c;媒体让ChatGPT写新闻稿&#xff0c;程序员让ChatGPT写代码甚至还带修BUG服…