Rumah pangkalan data tutorial mysql 自动备份数据库并发送邮件报告数据库

自动备份数据库并发送邮件报告数据库

Jun 07, 2016 pm 04:17 PM
hantar sandaran Laporan pangkalan data automatik mel

最近在一个做企业的一个内部系统,数据库采用的是SQL2000,为了保证数据的安全性,需要每天下班之后做数据备份,并且通过邮件的方式通知管理员备份情况。备份数据库很简单,用SQL代理建立一个作业,每天定时备份数据库即可,通过SQL2000来发邮件的话,在网上

   最近在一个做企业的一个内部系统,数据库采用的是SQL2000,,为了保证数据的安全性,需要每天下班之后做数据备份,并且通过邮件的方式通知管理员备份情况。备份数据库很简单,用SQL代理建立一个作业,每天定时备份数据库即可,通过SQL2000来发邮件的话,在网上找了些资料,发现有多种方式可以采用。

  一、通过SQL Mail

  SQL Mail 提供了一种从 Microsoft SQL Server 发送和阅读电子邮件的简单方法。原理是通过调用服务器上面的 MAPI 子系统来进行邮件发送,所以服务器上面需要安装诸如 Microsoft Outlook(不能是Outlook ExPRess) 之类的 MAPI 客户端,而且在发送邮件的时候,Outlook必须处于打开的状态。具体的设置方法可以通过网上查询。

  二、使用CDONTS

  通过调用本机的SMTP服务来发送邮件,所以服务器上必须安装IIS和SMTP。相应的存储过程为

  CREATE PROCEDURE [dbo].[sp_send_cdontsmail]

  @From varchar(100),

  @To varchar(100),

  @Subject varchar(100),

  @Body varchar(4000),

  @CC varchar(100) = null,

  @BCC varchar(100) = null

  AS

  Declare @MailID int

  Declare @hr int

  EXEC @hr = sp_OACreate 'CDONTS.NewMail', @MailID OUT

  EXEC @hr = sp_OASetProperty @MailID, 'From',@From

  EXEC @hr = sp_OASetProperty @MailID, 'Body', @Body

  EXEC @hr = sp_OASetProperty @MailID, 'BCC',@BCC

  EXEC @hr = sp_OASetProperty @MailID, 'CC', @CC

  EXEC @hr = sp_OASetProperty @MailID, 'Subject', @Subject

  EXEC @hr = sp_OASetProperty @MailID, 'To', @To

  EXEC @hr = sp_OAMethod @MailID, 'Send', NULL

  EXEC @hr = sp_OADestroy @MailID

  调用方法:

  exec sp_send_cdontsmail 'someone@shouji138.com','someone2@hks8.com','测试邮件标题','这里是邮件内容,推荐一个好的小说站,好看书吧,'

  三、使用CDOSYS

  微软已经在 Windows 2000、Windows xp 以及 Windows 2003 中淘汰了 CDONTS,所以使用CDOSYS是目前最好的解决方案。使用CDOSYS可以使用远程的SMTP服务器来发送邮件,我们通过测试163网易的免费邮箱,可以正常发送邮件,相应的存储过程如下:

  CREATE PROCEDURE sys_sendmail @To varchar(100) , @Bcc varchar(500), @Subject varchar(400)=" ",

  @Body varchar(4000) =" "

  AS

  Declare @smtpserver varchar(50) --SMTP服务器地址

  Declare @smtpusername varchar(50) --SMTP服务器用户名

  Declare @smtpuserpassWord varchar(50) --SMTP服务器密码

  set @smtpserver = 'smtp.163.com'

  set @smtpusername = 'yourname@163.com' --这里设置成你的163邮箱用户名

  set @smtpuserpassword = 'password' --这里设置成你的163邮箱密码

  Declare @object int

  Declare @hr int

  EXEC @hr = sp_OACreate 'CDO.Message', @object OUT

  EXEC @hr = sp_OASetProperty @object, 'Configuration.fields("").Value','2'

  EXEC @hr = sp_OASetProperty @object, 'Configuration.fields("").Value', @smtpserver

  --下面三条语句是smtp验证,如果服务器需要验证,则必须要这三句,你需要修改用户名和密码

  EXEC @hr = sp_OASetProperty @object, 'Configuration.fields("").Value','1'

  EXEC @hr = sp_OASetProperty @object, 'Configuration.fields("").Value',@smtpusername

  EXEC @hr = sp_OASetProperty @object, 'Configuration.fields("").Value',@smtpuserpassword

  EXEC @hr = sp_OAMethod @object, 'Configuration.Fields.Update', null

  EXEC @hr = sp_OASetProperty @object, 'To', @To

  EXEC @hr = sp_OASetProperty @object, 'Bcc', @Bcc

  EXEC @hr = sp_OASetProperty @object, 'From', @smtpusername

  EXEC @hr = sp_OASetProperty @object, 'Subject', @Subject

  EXEC @hr = sp_OASetProperty @object, 'TextBody', @Body

  EXEC @hr = sp_OAMethod @object, 'Send', NULL

  --判断出错

  IF @hr 0

  BEGIN

  EXEC sp_OAGetErrorInfo @object

  print 'failed'

  return @object

  END

  PRINT 'success'

  EXEC @hr = sp_OADestroy @object

  GO

  调用存储过程发送邮件:exec sys_sendmail 'someone@shouji138.com','someone2@hks8.com','测试邮件标题','这里是邮件内容,手机主题,'

  从以上三种方法的优缺点比较来看,我们当然采取第三种方法,不需要在服务器上装别的组件和程序。我们可以在SQL代理中建立一个作业,调度设为每天下午6点,执行的数据库备份语句和发送邮件的SQL如下:

  declare @dbname varchar(50)

  set @dbname = 'dbtest' --设置数据库名

  declare @filename nvarchar(100)

  declare @time datetime

  set @time = getdate()

  set @filename= 'D:数据库自动备份'+@dbname+substring(replace(replace(replace(CONVERT(varchar, @time, 120 ),'-',''),' ',''),':',''),1,14 )+'.bak'

  --print @filename

  BACKUP DATABASE dbtest TO DISK = @filename WITH NOINIT, NOUNLOAD, NAME = N'BIS_data_backup', NOSKip , STATS = 10, NOFORMAT

  --下面获取备份之后文件的大小

  declare @size int

  declare @sizeM decimal (5, 2)

  select top 1 @size=backup_size

  from msdb.dbo.backupset

  where database_name = @dbname

  order by backup_start_date desc

  set @sizeM = CAST(@size as float)/1024/1024

  --print @sizeM

  --邮件内容

  declare @content varchar(2000)

  set @content='数据库自动备份成功。

  数据库名:'+@dbname+'

  备份文件名:'+@filename+'

  备份文件大小:'+convert(varchar,@sizeM)+'M

  备份时间:'+CONVERT(varchar, @time, 120 )+'

  这是一封系统自动发出的邮件,用来每天报告数据库自动备份情况,请不要直接回复。'

  --print @content

  --发送邮件

  EXECUTE dbtest.dbo.sys_sendmail 'dba@hks8.com','dba@shouji138.com',

  '数据库自动备份日报',@content

  go

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Bagaimana untuk menggunakan sandaran dan pemulihan MySQL dalam PHP? Bagaimana untuk menggunakan sandaran dan pemulihan MySQL dalam PHP? Jun 03, 2024 pm 12:19 PM

Membuat sandaran dan memulihkan pangkalan data MySQL dalam PHP boleh dicapai dengan mengikuti langkah berikut: Sandarkan pangkalan data: Gunakan arahan mysqldump untuk membuang pangkalan data ke dalam fail SQL. Pulihkan pangkalan data: Gunakan arahan mysql untuk memulihkan pangkalan data daripada fail SQL.

Bagaimanakah bahasa Go melaksanakan operasi penambahan, pemadaman, pengubahsuaian dan pertanyaan pangkalan data? Bagaimanakah bahasa Go melaksanakan operasi penambahan, pemadaman, pengubahsuaian dan pertanyaan pangkalan data? Mar 27, 2024 pm 09:39 PM

Bahasa Go ialah bahasa pengaturcaraan yang cekap, ringkas dan mudah dipelajari Ia digemari oleh pembangun kerana kelebihannya dalam pengaturcaraan serentak dan pengaturcaraan rangkaian. Dalam pembangunan sebenar, operasi pangkalan data adalah bahagian yang sangat diperlukan Artikel ini akan memperkenalkan cara menggunakan bahasa Go untuk melaksanakan operasi penambahan, pemadaman, pengubahsuaian dan pertanyaan pangkalan data. Dalam bahasa Go, kami biasanya menggunakan perpustakaan pihak ketiga untuk mengendalikan pangkalan data, seperti pakej sql yang biasa digunakan, gorm, dsb. Di sini kami mengambil pakej sql sebagai contoh untuk memperkenalkan cara melaksanakan operasi penambahan, pemadaman, pengubahsuaian dan pertanyaan pangkalan data. Andaikan kami menggunakan pangkalan data MySQL.

Bagaimanakah Hibernate melaksanakan pemetaan polimorfik? Bagaimanakah Hibernate melaksanakan pemetaan polimorfik? Apr 17, 2024 pm 12:09 PM

Pemetaan polimorfik hibernate boleh memetakan kelas yang diwarisi ke pangkalan data dan menyediakan jenis pemetaan berikut: subkelas bercantum: Cipta jadual berasingan untuk subkelas, termasuk semua lajur kelas induk. table-per-class: Cipta jadual berasingan untuk subkelas, yang mengandungi hanya lajur khusus subkelas. union-subclass: serupa dengan joined-subclass, tetapi jadual kelas induk menggabungkan semua lajur subclass.

iOS 18 menambah fungsi album 'Dipulihkan' baharu untuk mendapatkan semula foto yang hilang atau rosak iOS 18 menambah fungsi album 'Dipulihkan' baharu untuk mendapatkan semula foto yang hilang atau rosak Jul 18, 2024 am 05:48 AM

Keluaran terbaharu Apple bagi sistem iOS18, iPadOS18 dan macOS Sequoia telah menambah ciri penting pada aplikasi Photos, yang direka untuk membantu pengguna memulihkan foto dan video yang hilang atau rosak dengan mudah disebabkan pelbagai sebab. Ciri baharu ini memperkenalkan album yang dipanggil "Dipulihkan" dalam bahagian Alat pada apl Foto yang akan muncul secara automatik apabila pengguna mempunyai gambar atau video pada peranti mereka yang bukan sebahagian daripada pustaka foto mereka. Kemunculan album "Dipulihkan" menyediakan penyelesaian untuk foto dan video yang hilang akibat kerosakan pangkalan data, aplikasi kamera tidak disimpan ke pustaka foto dengan betul, atau aplikasi pihak ketiga yang menguruskan pustaka foto. Pengguna hanya memerlukan beberapa langkah mudah

Tutorial terperinci tentang mewujudkan sambungan pangkalan data menggunakan MySQLi dalam PHP Tutorial terperinci tentang mewujudkan sambungan pangkalan data menggunakan MySQLi dalam PHP Jun 04, 2024 pm 01:42 PM

Cara menggunakan MySQLi untuk mewujudkan sambungan pangkalan data dalam PHP: Sertakan sambungan MySQLi (require_once) Cipta fungsi sambungan (functionconnect_to_db) Fungsi sambungan panggilan ($conn=connect_to_db()) Laksanakan pertanyaan ($result=$conn->query()) Tutup sambungan ( $conn->close())

Bagaimana untuk mengendalikan ralat sambungan pangkalan data dalam PHP Bagaimana untuk mengendalikan ralat sambungan pangkalan data dalam PHP Jun 05, 2024 pm 02:16 PM

Untuk mengendalikan ralat sambungan pangkalan data dalam PHP, anda boleh menggunakan langkah berikut: Gunakan mysqli_connect_errno() untuk mendapatkan kod ralat. Gunakan mysqli_connect_error() untuk mendapatkan mesej ralat. Dengan menangkap dan mengelog mesej ralat ini, isu sambungan pangkalan data boleh dikenal pasti dan diselesaikan dengan mudah, memastikan kelancaran aplikasi anda.

Apl mel iOS 18 Apple mendapat sayap AI: carian dipertingkat, penulisan/balas pintar, klasifikasi dan ringkasan, dsb. Apl mel iOS 18 Apple mendapat sayap AI: carian dipertingkat, penulisan/balas pintar, klasifikasi dan ringkasan, dsb. Jun 11, 2024 pm 09:34 PM

Menurut berita pada 7 Jun, media teknologi AppleInsider menerbitkan catatan blog semalam, mendedahkan bahawa Apple sedang membangunkan Projek BlackPearl secara dalaman, yang terutamanya meningkatkan aplikasi e-mel dalam sistem iOS18 dan macOS15, membolehkan AI membantu pengguna mengarang dan membalas e-mel. Kandungan yang berkaitan diringkaskan seperti berikut: Projek Carian Dipertingkat BlackPearl mula-mula mempertingkatkan hasil carian e-mel, yang akan memaparkan lebih banyak maklumat daripada buku alamat, lokasi dan dokumen yang disimpan secara setempat. Balasan Pintar Selain itu, fungsi "Balasan Pintar" baharu dalam aplikasi e-mel akan menyediakan kandungan balasan yang sesuai berdasarkan model bahasa besar (LLM) Ajax yang dijalankan secara tempatan dan digabungkan dengan konteks e-mel. mengarang mel

Apr 09, 2024 pm 12:36 PM

HTML tidak boleh membaca pangkalan data secara langsung, tetapi ia boleh dicapai melalui JavaScript dan AJAX. Langkah-langkah termasuk mewujudkan sambungan pangkalan data, menghantar pertanyaan, memproses respons dan mengemas kini halaman. Artikel ini menyediakan contoh praktikal menggunakan JavaScript, AJAX dan PHP untuk membaca data daripada pangkalan data MySQL, menunjukkan cara untuk memaparkan hasil pertanyaan secara dinamik dalam halaman HTML. Contoh ini menggunakan XMLHttpRequest untuk mewujudkan sambungan pangkalan data, menghantar pertanyaan dan memproses respons, dengan itu mengisi data ke dalam elemen halaman dan merealisasikan fungsi HTML membaca pangkalan data.

See all articles