Register Register Member Login Member Login Member Login Forgot Password ??
PHP , ASP , ASP.NET, VB.NET, C#, Java , jQuery , Android , iOS , Windows Phone
 

Registered : 109,036

HOME > .NET Framework > Forum > C# try catch ถ้าเน็ตหลุดหรือเชื่อมต่อกับ database(เครื่อง Server) ไม่ได้ อยากให้มี countdown 30วินาที แล้วกลับมาทำงานใน Try ใหม่อีกครั้ง ทำยังไงครับ



 

C# try catch ถ้าเน็ตหลุดหรือเชื่อมต่อกับ database(เครื่อง Server) ไม่ได้ อยากให้มี countdown 30วินาที แล้วกลับมาทำงานใน Try ใหม่อีกครั้ง ทำยังไงครับ

 



Topic : 129646



โพสกระทู้ ( 249 )
บทความ ( 0 )



สถานะออฟไลน์




C# try catch ถ้าเน็ตหลุดหรือเชื่อมต่อกับ database(เครื่อง Server) ไม่ได้ อยากให้มี countdown 30วินาที แล้วกลับมาทำงานใน Try ใหม่อีกครั้ง ทำยังไงครับ

Code (C#)
try
{
   //Query
}
catch (Exception ex)
{
    //นับเวลาถอยหลัง 30วินาที 
    //เช็คการเชื่อมต่อ internet หรือ Database 
    //ถ้าเชื่อมต่อได้ให้กลับไปทำใน Try ใหม่ 
    //ถ้าไม่ได้ให้นับเวลาถอยหลัง 30วินาที แล้วเช็คใหม่อีกครั้ง จนกว่าจะได้
}


หรือมีวิธีอื่น ๆ ที่ดีกว่านี้ ขอคำแนะนำหน่อยครับ ขอบคุณมากครับ



Tag : .NET, Ms SQL Server 2008, C#







Move To Hilight (Stock) 
Send To Friend.Bookmark.
Date : 2017-12-06 19:52:41 By : nPointXer View : 2266 Reply : 20
 

 

No. 1



โพสกระทู้ ( 249 )
บทความ ( 0 )



สถานะออฟไลน์


งงคำถามกันไหมครับ สอบถามได้นะครับ คือปกติถ้ามันเชื่อมต่อไม่ได้ มันจะแสดง Popup ขึ้นมาว่าเชื่อมต่อไม่ได้ แต่ตอนนี้ผมอยากให้แสดงเป็นนับเวลาถอยหลังว่าจะเชื่อมต่อใหม่.. 30 วินาที countdown จนกว่าจะเชื่อมต่อได้ ถึงจะทำใน Try อะไรแบบนี้ครับ






แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2017-12-07 15:09:25 By : nPointXer
 


 

No. 2



โพสกระทู้ ( 317 )
บทความ ( 0 )



สถานะออฟไลน์


ใช้ Timmer ครับ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2017-12-07 15:20:44 By : OOP
 

 

No. 3



โพสกระทู้ ( 249 )
บทความ ( 0 )



สถานะออฟไลน์


ตอบความคิดเห็นที่ : 2 เขียนโดย : OOP เมื่อวันที่ 2017-12-07 15:20:44
รายละเอียดของการตอบ ::
ใช้อยู่ครับ ใช้นับถอยหลัง 30 วิ .. แต่ทำยังไงให้มันเข้าไปทำใน Try ใหม่ครับ ไม่ทราบต่อจากนี้

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2017-12-07 15:48:50 By : nPointXer
 


 

No. 4



โพสกระทู้ ( 74,058 )
บทความ ( 838 )

สมาชิกที่ใส่เสื้อไทยครีเอท

สถานะออฟไลน์
Twitter Facebook

ใช้ BackgroundWorker แล้วใช้ Sleep ครับ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2017-12-07 17:07:48 By : mr.win
 


 

No. 5



โพสกระทู้ ( 249 )
บทความ ( 0 )



สถานะออฟไลน์


ตอบความคิดเห็นที่ : 4 เขียนโดย : mr.win เมื่อวันที่ 2017-12-07 17:07:48
รายละเอียดของการตอบ ::
พี่วินหมายถึงแบบนี้หรอครับ ผมไม่ค่อยเข้าใจ

Code (C#)
        private void backgroundWorker1_DoWork(object sender, DoWorkEventArgs e)
        {            
            // Process 1
            //------------------------------------------------------------//
            percent = DoProcess(EnumProcess.Process1, percent);

            // Process 2
            //------------------------------------------------------------//
            percent = DoProcess(EnumProcess.Process2, percent);
        }

        private double DoProcess(EnumProcess process, double percent)
        {
           try
            {
                using (var conn = new SqlConnection(MyDB))
                {
                    conn.Open();

                    switch (process.ToString())
                    {
                        case "Process1":
                            using (cmd = new SqlCommand("Exec Procedure_A ", conn))
                            cmd.CommandTimeout = 0;
                            cmd.ExecuteNonQuery();
                            break;

                        case "Process2":
                            using (cmd = new SqlCommand("Exec Procedure_B ", conn))
                            cmd.CommandTimeout = 0;
                            cmd.ExecuteNonQuery();
                            break;
                    }
                }
            }
            catch (Exception)
            {
                    //นับเวลาถอยหลัง 30วินาที 
                    //เช็คการเชื่อมต่อ internet หรือ Database 
                    //ถ้าเชื่อมต่อได้ให้กลับไปทำใน Try ใหม่ 
                    //ถ้าไม่ได้ให้นับเวลาถอยหลัง 30วินาที แล้วเช็คใหม่อีกครั้ง จนกว่าจะได้

                    System.Threading.Thread.Sleep(30000);
            }//end try
        }



แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2017-12-07 18:02:22 By : nPointXer
 


 

No. 6



โพสกระทู้ ( 4,440 )
บทความ ( 23 )



สถานะออฟไลน์
Facebook

ถ้าใช้ timer ตั้ง interval = 30000(30s)
มันก็จะทำตามคำสั่งใน timer ทุก 30 วิกันเลยทีเดียวครับ

แล้วตอนนี้โค้ดใน timer เขียนไว้ยังไงมั่งครับ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2017-12-07 19:03:10 By : lamaka.tor
 


 

No. 7



โพสกระทู้ ( 249 )
บทความ ( 0 )



สถานะออฟไลน์


ตอบความคิดเห็นที่ : 6 เขียนโดย : lamaka.tor เมื่อวันที่ 2017-12-07 19:03:10
รายละเอียดของการตอบ ::
มีแค่นี้ครับผม
Code (C#)
        timer1 = new System.Windows.Forms.Timer();
        timer1.Tick += new EventHandler(timer1_Tick);
        timer1.Interval = 1000; // 1 second

        private void timer1_Tick(object sender, EventArgs e)
        {
            Countt--;
            if (Countt == 0)
            {
                timer1.Stop();
                button1.Text = "Start";

                button1.Enabled = false;
                button2.Enabled = false;
                button3.Enabled = false;
                PrepareListView();
                backgroundWorker1.RunWorkerAsync();
            }
            else
            {
                button1.Text = "Start (" + Countt.ToString() + ")";
            }
        }


แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2017-12-07 20:03:27 By : nPointXer
 


 

No. 8



โพสกระทู้ ( 4,440 )
บทความ ( 23 )



สถานะออฟไลน์
Facebook

ตอบความคิดเห็นที่ : 7 เขียนโดย : nPointXer เมื่อวันที่ 2017-12-07 20:03:27
รายละเอียดของการตอบ ::
Code (C#)
timer1.Interval = 30000;


แค่นี้ก็ทำงานทุก 30 วิ แล้วนะครับ

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2017-12-07 21:43:01 By : lamaka.tor
 


 

No. 9



โพสกระทู้ ( 249 )
บทความ ( 0 )



สถานะออฟไลน์


ตอบความคิดเห็นที่ : 8 เขียนโดย : lamaka.tor เมื่อวันที่ 2017-12-07 21:43:01
รายละเอียดของการตอบ ::
พอดีผมใช้ timer1 ไปแล้วกับ timer1_Tick ถ้าจะใช้อีกอัน ต้องเพิ่ม timer อีกอันหรอครับ
คือสร้าง timer2_Tick แล้วจะทำยังไงให้มันวนไปทำใน try (No. 5) อีกรอบครับไม่เข้าใจ

Code (C#)
timer2 = new System.Windows.Forms.Timer();
timer2.Tick += new EventHandler(timer2_Tick);
timer2.Interval = 30000; // 1000 = 1 second

private void timer2_Tick(object sender, EventArgs e)
{
    //???
}



แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2017-12-07 23:11:15 By : nPointXer
 


 

No. 10



โพสกระทู้ ( 4,440 )
บทความ ( 23 )



สถานะออฟไลน์
Facebook

Code (C#)
timer1 = new System.Windows.Forms.Timer();
timer1.Tick += new EventHandler(timer1_Tick);
timer1.Interval = 30000; // 30 second

private void timer1_Tick(object sender, EventArgs e)
{
    Countt--;
    if (Countt == 0)
    {
        timer1.Stop();
        button1.Text = "Start";

        button1.Enabled = false;
        button2.Enabled = false;
        button3.Enabled = false;
        PrepareListView();
      //  backgroundWorker1.RunWorkerAsync(); ไม่ต้องมี มันซ้ำซ้อน
    }
    else
    {
        button1.Text = "Start (" + Countt.ToString() + ")";
    }
}

ถ้าแบบนี้มันจะเช็คทุก 30 วิ อยู่แล้ว ครับ

timer2 มีไว้เพื่ออะไรรึครับ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2017-12-07 23:20:10 By : lamaka.tor
 


 

No. 11



โพสกระทู้ ( 4,440 )
บทความ ( 23 )



สถานะออฟไลน์
Facebook

หากเรายึดวัตถุประสงค์นี้
Code (C#)
try
{
   //Query
}
catch (Exception ex)
{
    //นับเวลาถอยหลัง 30วินาที 
    //เช็คการเชื่อมต่อ internet หรือ Database 
    //ถ้าเชื่อมต่อได้ให้กลับไปทำใน Try ใหม่ 
    //ถ้าไม่ได้ให้นับเวลาถอยหลัง 30วินาที แล้วเช็คใหม่อีกครั้ง จนกว่าจะได้
}


สามารถ เขียนบ้านๆได้แบบนี้เลยครบั

Code (C#)
try
{
   //Query
}
catch (Exception ex)
{
    //นับเวลาถอยหลัง 30วินาที 
    //เช็คการเชื่อมต่อ internet หรือ Database 
    //ถ้าเชื่อมต่อได้ให้กลับไปทำใน Try ใหม่ 
    //ถ้าไม่ได้ให้นับเวลาถอยหลัง 30วินาที แล้วเช็คใหม่อีกครั้ง จนกว่าจะได้

   do
        {
         //เช็คการเชื่อมต่อ internet หรือ Database 
       
         //นับเวลาถอยหลัง 30วินาที 
           System.Threading.Thread.Sleep(30000);
        } while (conn.state = System.Data.ConnectionState.Closed);
}


การใช้ Do และ Sleep(30000) บ้านๆตรงตัวตามคำถามเลยครับ
คือเช็คทุก 30 วิ จนกว่าจะคอนเนคได้ ถ้าได้ก็ ชิวๆไป ไม่ได้ก็คอนใหม่

อีก 30 วิ เจอกานนนน อะไรประมาณนั้น

แต่ในกรณที่ เราต้องการให้ เช็คการ คอนเนคทุก 30 วิ คนละความหมายกับด้านบนนะครับ

คือแบบแรก เรา คอนเนคไม่ได้ เลยต้อง รอ คอนเนคใหม่ทุก 30 วิ จนกว่าจะคอนได้
แบบที่2 คือไม่สนว่าจะคอนได้รึไม่ได้ แต่อยากให้คอนทุก 30 วิ

แบบนี้เราใช้ Timer แล้วกำหนด Interval = 30000

Code (C#)
timer1 = new System.Windows.Forms.Timer();
timer1.Tick += new EventHandler(timer1_Tick);
timer1.Interval = 30000; // 30 second

private void timer1_Tick(object sender, EventArgs e)
{
    //เช็คการเชื่อมต่อ internet หรือ Database 
}


แบบที่ 3 คือต้องการเช็คทุก 30 วิ แล้วถ้่าเช็คแล้วมัน คอนเน็คก็ให้ รีคอนเนคทุก 30 วิ


Code (C#)
timer1 = new System.Windows.Forms.Timer();
timer1.Tick += new EventHandler(timer1_Tick);
timer1.Interval = 30000; // 30 second

private void timer1_Tick(object sender, EventArgs e)
{
    //เช็คการเชื่อมต่อ internet หรือ Database 
}

void CheckConect()
{
try
{
   //Query
}
catch (Exception ex)
{
    //นับเวลาถอยหลัง 30วินาที 
    //เช็คการเชื่อมต่อ internet หรือ Database 
    //ถ้าเชื่อมต่อได้ให้กลับไปทำใน Try ใหม่ 
    //ถ้าไม่ได้ให้นับเวลาถอยหลัง 30วินาที แล้วเช็คใหม่อีกครั้ง จนกว่าจะได้

   do
        {
         //เช็คการเชื่อมต่อ internet หรือ Database 
       
         //นับเวลาถอยหลัง 30วินาที 
           System.Threading.Thread.Sleep(30000);
        } while (conn.state = System.Data.ConnectionState.Closed);
}
}


แบบที่ 3 ไม่แนะนำ เพราะ การเช็คแบบ รีคอนเนค จะชนกับ การคอนเนคทุก 30 วิ
เว้ากันซื่อๆก็คือ ถึงเราจะไม่รีคอนเนค มันก็ คอนเนคใหม่อยู่แล้ว

ทีนี้ก็เลือกเลยครับ ว่าจะใช้แบบ ที่ 1 2 3 หรือ มีวัตถุประสงค์ อื่นครับ

ปล.ลองทดสอบโค้ดดูก่อน ถ้าไม่ตรงค่อยว่ากันใหม่ล่าย
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2017-12-08 00:40:41 By : lamaka.tor
 


 

No. 12



โพสกระทู้ ( 249 )
บทความ ( 0 )



สถานะออฟไลน์


ตอบ No.11
ติดตรงนี้ครับ
3

ตอบ No.10
ผมใช้ timer1 ตั้งเวลาไว้ทุกๆ 45นาที ให้มีการ Sync ข้อมูลไปที่ Server

ทีนี้ติดปัญหาว่า ถ้ามีเน็ตหลุด หรือเชื่อมต่อกับฐาน Server ไม่ได้ มันจะขึ้น MessageBox Error ขึ้นมา
ผมไม่อยากให้มันไม่มี MessageBox Error ขึ้นมา (ตรงนี้ผมไม่ได้ใส่ MessageBox.Show มันก็ขึ้นมานะครับ)

เปลี่ยนเป็น รออีก 30 วิเชื่อมต่อใหม่จนกว่าจะได้ ถ้าเชื่อมต่อได้ค่อยไปทำใน Try ที่ค้างเมื่อกี้ใหม่จนเสร็จกระบวนการ แล้วไปรอ 45 นาทีทำอีกครั้งตามเดิม
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2017-12-08 13:57:57 By : nPointXer
 


 

No. 13



โพสกระทู้ ( 821 )
บทความ ( 0 )



สถานะออฟไลน์


ทำแบบนี้ได้ไหมครับ

Timer ตั้งเวลาทำงานไว้ที่ 30 วิ
เมื่อเริ่มทำงานให้ยุด Timer ไว้ก่อน
พอทำงานเสร็จ ไม่ว่าจะผ่าน หรือ ไม่ผ่าน ก็ค่อยเปิด Timer มาต่อ

ในกรณีที่ทำงานสำเร็จ ให้บรรทึกเวลาที่ผ่านเอาไว้ (สมมุติว่าเป็นค่า A)
แต่ถ้าไม่สำเร็จก็ไม่ต้องบรรทึกเวลา

Timer ที่ตั้งไว้ทุก 30 วิ
จะตรวจสอบเวลาปัจจุบัน กับ เวลาที่ A ที่ได้บันทึก
ถ้าเวลาห่างกัน 45 นาที
ก็จะเริ่มทำงานอีกครั้ง

ถ้าถึงเวลา 45 นาที ที่ต้องทำงาน
แล้วติดต่อ Server ไม่ได้
ค่าเวลา A จะเป็นเวลาเดิม

Timer ก็จะรออีก 30 วิ
แล้วก็จะทำงานใหม่อีกรอบ
มันจะรอ 30 วิไปเรื่อย ๆ จนทำงานได้
ถึงค่อยทิ้งระยะไปอีก 45 นาที
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2017-12-08 14:40:47 By : fonfire
 


 

No. 14



โพสกระทู้ ( 9,583 )
บทความ ( 2 )



สถานะออฟไลน์


ตอบความคิดเห็นที่ : 11 เขียนโดย : lamaka.tor เมื่อวันที่ 2017-12-08 00:40:41
รายละเอียดของการตอบ ::
... ขออนุญาต เอามาประยุกต์ เพื่อจะเป็นประโยชน์


Code (C#)
do{
	try{
		--Query
	}catch (Exception ex){
		// เช็คการเชื่อมต่อ internet หรือ Database 
		if(conn.state = System.Data.ConnectionState.Closed){
			int count_error = 0;
			do{
				// นับการเชื่อมต่อไม่ได้ติดต่อกัน จำนวนกี่ครั้ง เพื่อจบโปรแกรม 
				if( (++count_error)>100) break;
				//นับเวลาถอยหลัง 30วินาที 
				System.Threading.Thread.Sleep(30000);
				//ทำการเชื่อมต่อ
				// ตรวจสอบการเชื่อมต่อ				
			} while (conn.state = System.Data.ConnectionState.Closed);
			// เชื่อมต่อได้ ทำงานต่อ
		}
	}
} while (conn.state = System.Data.ConnectionState.Open);

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2017-12-08 15:34:31 By : Chaidhanan
 


 

No. 15



โพสกระทู้ ( 4,440 )
บทความ ( 23 )



สถานะออฟไลน์
Facebook

ตอบความคิดเห็นที่ : 12 เขียนโดย : nPointXer เมื่อวันที่ 2017-12-08 13:57:57
รายละเอียดของการตอบ ::
1. ตรง Error เพราะผมเขียนสดครับ
2. ถ้ามีเน็ตหลุด หรือเชื่อมต่อกับฐาน Server ไม่ได้ มันจะขึ้น MessageBox Error ขึ้นมา ต้องดูว่า error ว่าอะไรแล้วมาจากไหนครับ

ทางที่ดี ลองเอา โค้ดที่เขียนตอนนี้ มาดูครับ ว่าเขียนอะไรไปแล้ว
และ ผล ผิดพลาดจากจุดไหนบ้างครับ
จะได้แก้ไขเป็นส่วนๆไปครับ

แต่เป้าหมายก็คือ เช็คการคอนเนค ใช่ไม๊ครับ ถ้าไม่มีการคอนเนค หรือ หลุดไปก็ให้รีคอนเนคจนกว่าจะได้

ใช่ผมเข้าใจถูกไม๊ครับ


แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2017-12-08 16:04:35 By : lamaka.tor
 


 

No. 16



โพสกระทู้ ( 249 )
บทความ ( 0 )



สถานะออฟไลน์


ผมอ่านแล้วทุกคอมเม้น ผมกำลังเอาไปประยุกต์ใช้นะครับ ได้ผลยังไงจะมาบอกครับ :)

เบื้องต้นจะใช้ตัวนี้ทดสอบครับ
Code (C#)
do
{
    MessageBox.Show("เข้ามาละ");
    System.Threading.Thread.Sleep(10000);
} while (conn.State == ConnectionState.Open); //ConnectionState.Closed



ประวัติการแก้ไข
2017-12-08 16:15:53
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2017-12-08 16:14:04 By : nPointXer
 


 

No. 17



โพสกระทู้ ( 4,440 )
บทความ ( 23 )



สถานะออฟไลน์
Facebook

ตอบความคิดเห็นที่ : 16 เขียนโดย : nPointXer เมื่อวันที่ 2017-12-08 16:14:04
รายละเอียดของการตอบ ::
จัดไปครับ

Code (C#)
do
{
    MessageBox.Show("เข้ามาละ");
    System.Threading.Thread.Sleep(10000);
} while (conn.State == ConnectionState.Open); //ConnectionState.Closed


จะทำงานแค่ครั้งเดียว หมายความว่าถ้ามัน คอนเนค แล้ว โค้ดนี้ก็ทำอะไรมันไม่ได้(ลอยนวลกันเลย)
เพราะงั้นอาจจะต้องใช้ timer มาคอยเช็ค โดยใช้ Interval =10000 อีกทีหนึ่ง

ผมใช้คำว่า Interval แทนการ ใช้คำว่า ทุกๆ 10 วิ เพื่อให้สื่อความหมายที่ต่างกันแต่วิธีการเดียวกัน


แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2017-12-08 16:45:06 By : lamaka.tor
 


 

No. 18



โพสกระทู้ ( 249 )
บทความ ( 0 )



สถานะออฟไลน์


ตอบความคิดเห็นที่ : 14 เขียนโดย : Chaidhanan เมื่อวันที่ 2017-12-08 15:34:31
รายละเอียดของการตอบ ::
เอา do while มาครอบ Try ไม่ได้ครับ เหมือนต้อง Connect DB ก่อน พอดีผมใช้แบบนี้ เลยทำได้เฉพาะใน Try

Code (C#)
    
using System;
using System.IO;
using System.Security;
using System.Security.Cryptography;
using System.Runtime.InteropServices;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Drawing.Printing;
using System.Text;
using System.Windows.Forms;
using System.Configuration;
using System.Data.SqlClient;
using System.Globalization;
using System.Threading;
using System.Threading.Tasks;

namespace TEST
{
   public partial class Form1 : Form
   {
           SqlConnection conn = new SqlConnection();
           SqlDataAdapter da = new SqlDataAdapter();
           DataTable dt = new DataTable();
           SqlCommand cmd = new SqlCommand();
           string MyDB = ConfigurationManager.ConnectionStrings["DBConnect"].ConnectionString; //app.config
   
           public Form1()
           {
               InitializeComponent(); 
           }

           private void Form1_Load(object sender, EventArgs e)
           {
               try
               {
                   using (var conn = new SqlConnection(MyDB))
                   {
                       conn.Open();
                       using (cmd = new SqlCommand("Exec SyncITEM ", conn))
                       cmd.ExecuteNonQuery();
                   }
               }
               catch (Exception ex)
               {   
                   //MessageBox.Show(ex.Message);
               }//end try
           }
   }
}




ประวัติการแก้ไข
2017-12-08 17:14:28
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2017-12-08 17:09:57 By : nPointXer
 


 

No. 19



โพสกระทู้ ( 249 )
บทความ ( 0 )



สถานะออฟไลน์


ตอนนี้ใช้แบบนี้ครับ ทดลองแล้วได้ผล ผิดถูกยังไงแนะนำด้วยครับ ไม่รู้ระยะยาวจะเป็นอะไรไหม อาจจะต้องเช็คใน catch ครับว่า ถ้าเกี่ยวกับการติดต่อ Server หรือ Internet หลุด ให้ Sleep 30 วิแล้วลองใหม่ แต่ถ้าเป็น Error อย่างอื่นให้หยุดการทำงานโปรแกรม แล้วฟ้องให้ผู้ใช้ทราบ


Code (C#)
               bool tryAgain = true;
               while (tryAgain)
               {
                 try
                 {
                     using (var conn = new SqlConnection(MyDB))
                     {
                         conn.Open();
                         using (cmd = new SqlCommand("Exec SyncITEM ", conn))
                         cmd.ExecuteNonQuery();
                     }
                     tryAgain = false;
                 }
                 catch (Exception)
                 {   
                      System.Threading.Thread.Sleep(30000);
                      //ตรงนี้เดี๋ยวจะทำเป็น Timer นับถอยหลังแทน เป็นข้อความแจ้งเตือนประมาณว่า 
                      //ไม่สามารถติดต่อ Server ได้ กำลัง เชื่อมต่อ อีกครั้ง ในอีก ... วินาที
                 }//end try
               }



ประวัติการแก้ไข
2017-12-08 17:14:45
2017-12-08 17:15:12
2017-12-08 17:19:37
2017-12-08 17:32:10
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2017-12-08 17:13:43 By : nPointXer
 


 

No. 20



โพสกระทู้ ( 249 )
บทความ ( 0 )



สถานะออฟไลน์


ขอบคุณทุกๆคนครับ ได้แนวคิดใหม่เยอะเลย
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2017-12-08 17:35:16 By : nPointXer
 

   

ค้นหาข้อมูล


   
 

แสดงความคิดเห็น
Re : C# try catch ถ้าเน็ตหลุดหรือเชื่อมต่อกับ database(เครื่อง Server) ไม่ได้ อยากให้มี countdown 30วินาที แล้วกลับมาทำงานใน Try ใหม่อีกครั้ง ทำยังไงครับ
 
 
รายละเอียด
 
ตัวหนา ตัวเอียง ตัวขีดเส้นใต้ ตัวมีขีดกลาง| ตัวเรืองแสง ตัวมีเงา ตัวอักษรวิ่ง| จัดย่อหน้าอิสระ จัดย่อหน้าชิดซ้าย จัดย่อหน้ากึ่งกลาง จัดย่อหน้าชิดขวา| เส้นขวาง| ขนาดตัวอักษร แบบตัวอักษร
ใส่แฟลช ใส่รูป ใส่ไฮเปอร์ลิ้งค์ ใส่อีเมล์ ใส่ลิ้งค์ FTP| ใส่แถวของตาราง ใส่คอลัมน์ตาราง| ตัวยก ตัวห้อย ตัวพิมพ์ดีด| ใส่โค้ด ใส่การอ้างถึงคำพูด| ใส่ลีสต์
smiley for :lol: smiley for :ken: smiley for :D smiley for :) smiley for ;) smiley for :eek: smiley for :geek: smiley for :roll: smiley for :erm: smiley for :cool: smiley for :blank: smiley for :idea: smiley for :ehh: smiley for :aargh: smiley for :evil:
Insert PHP Code
Insert ASP Code
Insert VB.NET Code Insert C#.NET Code Insert JavaScript Code Insert C#.NET Code
Insert Java Code
Insert Android Code
Insert Objective-C Code
Insert XML Code
Insert SQL Code
Insert Code
เพื่อความเรียบร้อยของข้อความ ควรจัดรูปแบบให้พอดีกับขนาดของหน้าจอ เพื่อง่ายต่อการอ่านและสบายตา และตรวจสอบภาษาไทยให้ถูกต้อง

อัพโหลดแทรกรูปภาพ

Notice

เพื่อความปลอดภัยของเว็บบอร์ด ไม่อนุญาติให้แทรก แท็ก [img]....[/img] โดยการอัพโหลดไฟล์รูปจากที่อื่น เช่นเว็บไซต์ ฟรีอัพโหลดต่าง ๆ
อัพโหลดแทรกรูปภาพ ให้ใช้บริการอัพโหลดไฟล์ของไทยครีเอท และตัดรูปภาพให้พอดีกับสกรีน เพื่อความโหลดเร็วและไฟล์ไม่ถูกลบทิ้ง

   
  เพื่อความปลอดภัยและการตรวจสอบ กระทู้ที่แทรกไฟล์อัพโหลดไฟล์จากที่อื่น อาจจะถูกลบทิ้ง
 
โดย
อีเมล์
บวกค่าให้ถูก
<= ตัวเลขฮินดูอารบิก เช่น 123 (หรือล็อกอินเข้าระบบสมาชิกเพื่อไม่ต้องกรอก)







Exchange: นำเข้าสินค้าจากจีน, Taobao, เฟอร์นิเจอร์, ของพรีเมี่ยม, ร่ม, ปากกา, power bank, แฟลชไดร์ฟ, กระบอกน้ำ

Load balance : Server 04
ThaiCreate.Com Logo
© www.ThaiCreate.Com. 2003-2024 All Rights Reserved.
ไทยครีเอทบริการ จัดทำดูแลแก้ไข Web Application ทุกรูปแบบ (PHP, .Net Application, VB.Net, C#)
[Conditions Privacy Statement] ติดต่อโฆษณา 081-987-6107 อัตราราคา คลิกที่นี่