>데이터 베이스 >MySQL 튜토리얼 >저장된 이메일 주소를 사용하여 SQL Server에서 이메일을 보내려면 어떻게 해야 합니까?

저장된 이메일 주소를 사용하여 SQL Server에서 이메일을 보내려면 어떻게 해야 합니까?

Linda Hamilton
Linda Hamilton원래의
2024-12-27 15:37:10250검색

How Can I Send Emails from SQL Server Using Stored Email Addresses?

저장된 이메일 주소를 사용하여 SQL Server에서 이메일 보내기

이메일을 보낼 수 있도록 SQL Server 데이터베이스를 강화하는 것은 다양한 시나리오에서 필수적인 작업입니다. 이메일 주소가 테이블에 저장되어 있고 이메일 알림을 트리거해야 한다고 가정해 보겠습니다. 이 문서에서는 T-SQL 프로그래밍 언어를 활용하여 이를 달성하기 위한 포괄적인 접근 방식을 보여줍니다.

1단계: 데이터베이스 메일 설정 구성

이메일을 보내기 전에 다음을 설정해야 합니다. 데이터베이스 메일 인프라를 구축하세요. SQL Server Management Studio의 데이터베이스 메일 구성 마법사를 사용하여 프로필, 계정 및 전역 설정을 만듭니다. 이렇게 하면 SQL Server 환경 내에서 이메일 배달이 가능해집니다.

2단계: 확장 저장 프로시저 및 데이터베이스 메일 활성화

이메일 전송에 필요한 저장 프로시저를 사용하려면, 다음 명령을 실행하세요:

sp_CONFIGURE 'show advanced', 1
GO
RECONFIGURE
GO
sp_CONFIGURE 'Database Mail XPs', 1
GO
RECONFIGURE
GO

3단계: 싱글 보내기 이메일

하드코딩된 이메일 주소가 포함된 단일 이메일을 보내려면 sp_send_dbmail 절차를 사용하십시오.

USE msdb
GO
EXEC sp_send_dbmail @profile_name='yourprofilename',
@recipients='[email protected]',
@subject='Test message',
@body='This is the body of the test message.
Congrates Database Mail Received By you Successfully.'

4단계: 이메일 주소 테이블 반복

테이블에 저장된 여러 수신자에게 이메일을 보내려면 테이블을 반복할 수 있습니다. while 루프 사용:

DECLARE @email_id NVARCHAR(450), @id BIGINT, @max_id BIGINT, @query NVARCHAR(1000)

SELECT @id=MIN(id), @max_id=MAX(id) FROM [email_adresses]

WHILE @id<=@max_id
BEGIN
    SELECT @email_id=email_id 
    FROM [email_adresses]

    set @query='sp_send_dbmail @profile_name=''yourprofilename'',
                        @recipients='''+@email_id+''',
                        @subject=''Test message'',
                        @body=''This is the body of the test message.
                        Congrates Database Mail Received By you Successfully.'''

    EXEC @query
    SELECT @id=MIN(id) FROM [email_adresses] where id>@id

END

이 포괄적인 접근 방식을 사용하면 수신자의 이메일 주소가 테이블에 저장되어 있는지 여부에 관계없이 SQL Server에서 이메일을 효율적으로 보낼 수 있습니다.

위 내용은 저장된 이메일 주소를 사용하여 SQL Server에서 이메일을 보내려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.