一、首先要对本地数据库做配置

1.通过使用数据库邮件配置向导和sp_configure存储过程配置启用数据库邮件:

注:服务器名称填写发送服务器的路径或者IP,电子邮件地址为寄件者地址

配置好数据库邮件账户和配件文件后,使用SQL   Mail    XPs选项在此服务器上启用SQL    Mail(改选项默认是关闭的)

sp_configure 'show  advanced  options' , 1

go

Reconfigure;

go

sp_configure 'SQL Mail  XPs' , 1

go

Reconfigure;

go

设置立即生效,无需停止并重新重启服务器

查看数据库邮件日志:

二、收到郵件顯示

三、存储过程代码

USE     数据库名称

GO

SET  ANSI_NULLS  ON

GO

SET QUOTED_IDENTIFIER  ON

GO

CREATE  PROCEDURE  存储过程名称

AS

BEGIN

  SET NOCOUNT ON;

    DECLARE     @MailTo          NVARCHAR(MAX)

     DECLARE     @Mailcc      NVARCHAR(MAX)

     DECLARE     @MailBcc    NVARCHAR(MAX)

      DECLARE     @MailSubject   NVARCHAR(255)

    DECLARE     @MailBody    NVARCHAR(MAX)

      DECLARE     @MailFormat   NVARCHAR(20)

     DECLARE     @SignCount    NVARCHAR(50)

     DECLARE      @DayID                NVARCHAR(20)

SET @DayId=CONVERT(NVARCHAR(10),DATEADD(DAY,-1,GETDATE()),111)

SELECT @SignCount=COUNT(1) FROM  [GSClassDB].[dbo].[Class_Abnorm] WHERE DayID='2017/12/03'
 
 SET @MailSubject='非責任制出勤共'+@SignCount+'筆,請注意查收!'
 SET @MailTo='ximi@com'
 SET @Mailcc='ximi@com'
 SET @MailBcc=''
 SET @MailBody=''
 SET @MailFormat='HTML'
 SET @MailBody=
   N'Dear ALL:<br>非責任制出勤共'+@SignCount+'筆,請注意查收,謝謝!<br><H4>&nbsp;&nbsp;&nbsp;列表如下:&nbsp;&nbsp;&nbsp;</H>'+  
         N'<table border="1"  style="font-size:11px;text-align:center"  width="60%">'+
         N'<tr style="font-size:11"><th>工號</th>'+
         N'<th>姓名</th>'+
         N'<th>部门</th>'+
         CAST( ( SELECT 
       td=EmpID, ' ' ,
       td=EmpName, ' ' ,
       td=DeptID, ' '
       FROM  [GSClassDB].[dbo].[Class_Abnorm] WHERE DayID='2017/12/03'
         FOR XML PATH( ' t r ' ),TYPE
         )AS NVARCHAR(MAX))+
         N'</table><br>以上为系统发送,请勿回复,谢谢!!<资讯系统部-课>'
        
        
         DECLARE @i int
       BEGIN
   SET @i=0;
   IF(@SignCount>1)
   EXEC msdb.dbo.sp_send_dbmail 
   @profile_name='ximi',
   @recipients=@MailTo,
   @copy_recipients=@Mailcc,
   @blind_copy_recipients=@MailBcc,
   @subject=@MailSubject,
   @body=@MailBody,
   @body_format=@MailFormat
   SET @i=1;
    END
        
END

SQL Server2008本地数据库调用SP发送邮件的更多相关文章

  1. SQL Server2008附加数据库之后显示为只读时解决方法

    啰嗦的话就不多说了,直入主题吧! 方案一: 碰到这中情况一般是使用的sa账户登录的,只要改为Windows身份验证,再附加数据库即可搞定. 方案二: 使用sa登录SQL Server2008附加数据库 ...

  2. SQL Server2008附加数据库之后显示为只读

    SQL Server2008附加数据库之后显示为只读时解决方法 啰嗦的话就不多说了,直入主题吧! 方案一: 碰到这中情况一般是使用的sa账户登录的,只要改为Windows身份验证,再附加数据库即可搞定 ...

  3. (转载)SQL Server2008附加数据库之后显示为只读时解决方法

    SQL Server2008附加数据库之后显示为只读时解决方法 啰嗦的话就不多说了,直入主题吧! 方案一: 碰到这中情况一般是使用的sa账户登录的,只要改为Windows身份验证,再附加数据库即可搞定 ...

  4. SQL Server2008 R2 数据库镜像实施手册(双机)SQL Server2014同样适用

    这篇文章主要介绍了SQL Server2008 R2 数据库镜像实施手册(双机)SQL Server2014同样适用,需要的朋友可以参考下 一.配置主备机 1. 服务器基本信息 主机名称为:HOST_ ...

  5. [转] sql server 跨数据库调用存储过程

    A库存储过程: create PROCEDURE [dbo].[spAAAForTest] ( ) =null , ) =null ) AS BEGIN select N'A' AS a , N'B' ...

  6. SQL Server2008附加数据库失败

    今天旁晚时分,我准备把老师在上课时候发给我们的一个数据库附加到我的SQL Server2008上面去,本来在学校机房用的SQL Server2000是很顺利地就成功了,但是把*.mdf文件附加到我的0 ...

  7. SQL Server 本地数据库登录不上 解决方法

    sql本地数据库登录不了的话.先看看自己计算机 服务 SQL server  (MSSQLSERVER)  没有打开的话,请打开. 今天说的情景模式是  你误删了windows登录:禁用了sa登录:s ...

  8. SQL Server2008分离数据库

    1.右击数据库 2.Tasks 3.点击Detach 4.选取Drop Connections-->点击确定 5.开启本地数据库默认存储路径C:\Program Files\Microsoft ...

  9. SQL Server2008创建数据库语法

    use mastergo if exists(select * from sys.databases where name='MySchool') drop database MySchool  -- ...

随机推荐

  1. Qt--core模块概述

    QtCore模块是所有其它Qt模块的基础,包含以下核心功能: Qt Data Types:数据类型Qt Object Model:对象模型(包括元对象模型.属性系统.信号与槽机制.对象树)Input/ ...

  2. MySQL TiDB PingCAP mydumper

    MySQL备份之[mydumper 学习] - jyzhou - 博客园https://www.cnblogs.com/zhoujinyi/p/3423641.html maxbube/mydumpe ...

  3. windows下安装anaconda和tensorflow

    anaconda确实很好用,省去了很多麻烦,现在我个人推荐直接使用anaconda. anaconda的特点:可以存在多个python环境,要使用某一个环境的话,就需要切换到这个环境,安装.卸载包都是 ...

  4. MyBatis原理总结(代码实现流程)

    我们在实际开发中,越简单越好,所以都是采用不写Dao实现类的方式.不管是使用xml还是直接配置. 但是MyBatis是支持写Dao实现类的 注意sqlSession是这里面的一个灵魂,有很多执行api ...

  5. k8s记录-下载k8s相关二进制包(一)

    1)软件清单操作系统:CentOS7Kubernetes版本:v1.14.2flannel:v0.10.0ectd3:v3.3.11Docker版本:v18.09.0-ceDocker-compose ...

  6. Linux记录-批量更改当前目录的文件后缀名

    #!/bin/bash path=. for file in $(ls $path) do if [ -f $file ] then filename=${file%.*} bak=${file#*. ...

  7. Linux系统调优——Memory内存(二)

    (1).查看Memory(内存)运行状态相关工具 1)free命令查看内存使用情况 [root@youxi1 ~]# free -m //-m选项,以MB为单位显示 total used free s ...

  8. 一秒解决--------No compiler is provided in this environment. Perhaps you are running on a JRE rather than a JDK?

    在打war包时候遇到错误: Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.6.0:compile (d ...

  9. NETTY keeplive 参数,心跳检测

    当设置为true的时候,TCP会实现监控连接是否有效,当连接处于空闲状态的时候,超过了2个小时,本地的TCP实现会发送一个数据包给远程的 socket,如果远程没有发回响应,TCP会持续尝试11分钟, ...

  10. idea能用下划线替换红色报错吗?我色弱,用idea简直太痛苦了

    看看下图的idea,如果某个类的包路径没有引进来,使用颜色来提示,这对于色弱的程序员简直是一种折磨,有没有可以改成eclipse的那种报错提示方式? 个人感觉idea真的没有eclipse友好,也许是 ...