在那种情况下SQL Server数据库中SMO进度条不显示?

此文章主要向大家讲述的是在那种情况下会出现SQL Server数据库中SMO备份数据库进度条不显示,同时存在一个十分奇怪的问题,用SMO备份SQL Server数据库时不显示进度条,也就是进度条事件PercentComplete不触发。

 

今天试了一下,果然有点奇怪。

 

一个奇怪的问题,用SMO备份SQL Server数据库时不显示进度条,也就是进度条事件PercentComplete不触发。

 

今天试了一下,果然有点奇怪。

 

代码如下:

 

  1. using Microsoft.SqlServer.Management.Smo;  
  2. using Microsoft.SqlServer.Management.Common;  
  3. private void btnBackup_Click(object sender, EventArgs e)  
  4. {  
  5. btnBackup.Enabled = false;  
  6. Thread tr = new Thread(new ThreadStart(doBackup));  
  7. tr.Priority = ThreadPriority.AboveNormal;  
  8. tr.Start();  
  9. //Thread.Sleep(3000);  
  10. }  
  11. /// <summary> 
  12. /// 备份数据库  
  13. /// </summary> 
  14. public void doBackup()  
  15. {  
  16. pbDemo.Value = 0;  
  17. pbDemo.Maximum = 100;  
  18. pbDemo.Style = ProgressBarStyle.Blocks;  
  19. //pbDemo.Step = 10;  
  20. Server srv = new Server(@"(local)");  
  21. Backup backup = new Backup();  
  22. backup.Action = BackupActionType.Database;  
  23. backup.Database = "btnet";  
  24. backup.Incremental = false;  
  25. backup.Devices.Add(new BackupDeviceItem(@"C:\agronet09.bak", DeviceType.File));  
  26. backup.Initialize = true;  
  27. backup.PercentCompleteNotification = 10;  
  28. backup.PercentComplete += new PercentCompleteEventHandler(backup_PercentComplete);  
  29. //backup.Checksum = true;  
  30. backup.SqlBackup(srv);  
  31. }  
  32. public void backup_PercentComplete(object sender, Microsoft.SqlServer.Management.Smo.PercentCompleteEventArgs e)  
  33. {  
  34. this.Invoke(new displayProgress_delegate(displayProgress), e.Percent);  
  35. //Application.DoEvents();  
  36. }  
  37. public delegate void displayProgress_delegate(int progress);  
  38. public void displayProgress(int progress)  
  39. {  
  40. this.lbProgress.Text = "已完成[" + progress.ToString() + " %]";  
  41. pbDemo.Value = progress;  
  42. btnBackup.Enabled = (progress == 100);  
  43. }  

症状如下:结果正确执行,但进度条不显示。

刚开始以为是线程问题,后来发现不是这个原因。

又试了另外一段代码

 

  1. using Microsoft.SqlServer.Management.Smo;  
  2. using Microsoft.SqlServer.Management.Common;  
  3. using System.Diagnostics;  
  4. static void Main(string[] args)  
  5. {  
  6. BackupDatabase("ap4\\agronet09", "agronet2008", "c:\\Northind_3.bak");  
  7. Console.WriteLine(Environment.NewLine + "Press any key to continue.");  
  8. Console.ReadKey();  
  9. }  
  10. public static void BackupDatabase(string serverName, string databaseName, string fileName)  
  11. {  
  12. Console.WriteLine("*** Backing up ***");  
  13. Server server = new Server(serverName);  
  14. Backup backup = new Backup();  
  15. backup.Action = BackupActionType.Database;  
  16. backup.Database = databaseName;  
  17. backup.Incremental = false;  
  18. backup.Initialize = true;  
  19. backup.LogTruncation = BackupTruncateLogType.Truncate;  
  20. BackupDeviceItem backupItemDevice = new BackupDeviceItem(fileName, DeviceType.File);  
  21. backup.Devices.Add(backupItemDevice);  
  22. backup.PercentCompleteNotification = 10;  
  23. backup.PercentComplete += backup_PercentComplete;  
  24. backup.Complete +=backup_Complete;  
  25. backup.SqlBackup(server);  
  26. }  
  27. protected static void backup_PercentComplete(object sender, PercentCompleteEventArgs e)  
  28. {  
  29. Console.WriteLine(e.Percent + "% processed.");  
  30. //Application.();  
  31. System.Threading.Thread.Sleep(1000);  
  32. }  
  33. protected static void backup_Complete(object sender, ServerMessageEventArgs e)  
  34. {  
  35. Console.WriteLine(Environment.NewLine + e.ToString());  
  36. }  

结果还是不显示。

后来突然想到会不会是文件太小,试了一个200M的数据文件,果然成功显示:

 

 

后来经反复实验,发现SQL server 2000约在数据文件加日志文件大于6M左右时显示进度条。

 

而Sql server 2008 r2大约在3M时显示进度条。可能跟机器也有关系。

 

以上的相关内容就是对SQL Server数据库中SMO备份数据库进度条的介绍,望你能有所收获。

【编辑推荐】

  1. C#来对SQL Server存储过程进行创建
  2. SQL Server索引实际结构的理解
  3. 添加Microsoft SQL Server 2000 Desktop Engine
  4. 安装MS SQL Server 2000失败的缘由是什么?
  5. Sql Server 日期格式化之函数GETDATE() 代码

 

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/232744.html<

(0)
运维的头像运维
上一篇2025-04-20 07:37
下一篇 2025-04-20 07:38

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注