กระทู้เก่าบอร์ด อ.Yeadram
1,944 7
URL.หัวข้อ /
URL
ยกเลิกคำเตือนใน Nodata ของรายงาน
Private Sub Report_NoData(Cancel As Integer)
MsgBox "No data found! Closing report."
DoCmd.SetWarnings No
Cancel = True
End Sub
เมื่อไม่มีข้อมูล
ก็จะมีคำเตือนแรก nodata found!closing report
หลังจากนั้น ก็จะมีำคำเตือนขึ้นมาอีก
ของ access เอง
แอคชั่น open report ถูกยกเลิก
ถ้าเราไม่ต้องการคำเตือนอันหลังนี้
ต้องไปสั่งในcode อย่างไรครับ
MsgBox "No data found! Closing report."
DoCmd.SetWarnings No
Cancel = True
End Sub
เมื่อไม่มีข้อมูล
ก็จะมีคำเตือนแรก nodata found!closing report
หลังจากนั้น ก็จะมีำคำเตือนขึ้นมาอีก
ของ access เอง
แอคชั่น open report ถูกยกเลิก
ถ้าเราไม่ต้องการคำเตือนอันหลังนี้
ต้องไปสั่งในcode อย่างไรครับ
7 Reply in this Topic. Dispaly 1 pages and you are on page number 1
2 @R13680
ยังหาวิธีไม่ได้เลยครับ
ไปดักทุกที่ด้วยคำสั่ง
set warnings no
ทั้งในรายงาน ทุกอีเวน
และในฟอร์มที่ใช้คำสั่งคลิกให้เปิดรายงาน
ขอบคุณครับ
ไปดักทุกที่ด้วยคำสั่ง
set warnings no
ทั้งในรายงาน ทุกอีเวน
และในฟอร์มที่ใช้คำสั่งคลิกให้เปิดรายงาน
ขอบคุณครับ
3 @R13715
ไม่ทราบมีทางตรวจสอบอย่างอื่นหรือไม่
เพื่อยกเลิกคำเตือน แอคชั่น open report ถูกยกเลิก
ลองทำทุกอย่างที่เกียวกับการเปิดรายงานแล้ว
ทุกอีเวน แม้นแต่ในฟอร์มที่มีปุ่มกดเปิดสั่งพิ่มพ์รายงาน
ยังไม่ได้ผล
เพื่อยกเลิกคำเตือน แอคชั่น open report ถูกยกเลิก
ลองทำทุกอย่างที่เกียวกับการเปิดรายงานแล้ว
ทุกอีเวน แม้นแต่ในฟอร์มที่มีปุ่มกดเปิดสั่งพิ่มพ์รายงาน
ยังไม่ได้ผล
4 @R13717
ลองส่ง file เข้า mail มาให้ดูดีกว่าครับ
5 @R13723
Private Sub Command12_Click() On Error GoTo Err_Command12_Click Dim stDocName As String DoCmd.SetWarnings False stDocName = "RSPS2A4" DoCmd.OpenReport stDocName, acPreview Exit_Command12_Click: Exit Sub Err_Command12_Click: ' MsgBox Err.Description Resume Exit_Command12_Click ทำอย่างที่ อ.access hotline ก็ได้ครับ หรือ remark ตรง MsgBox Err.Description ไว้ก็จะไม่มีคำเตือนออกมาครับ(ดังที่ผม remark ไว้ให้ดูครับ) End Sub
code อันหลังนี้ ทำแล้วใช้ได้
ผมแก้ไปที่ปุ่ม preview ครับ Private Sub Command12_Click() On Error Resume Next Dim stDocName As String DoCmd.SetWarnings False stDocName = "RSPS2A4" DoCmd.OpenReport stDocName, acPreview End Sub
แต่อยากรู้อันแรก ที่ิคุณ badman แจ้งไว้ สงสัย
บอกว่าทำตามวิธีที่สองก็ได้
หรือไม่ก็ ใช้ remark ตรง Msgbox Err.Description (ดังที่ผมremarkไว้ให้ดูครับ)
ตรงนี้ครับ อยากรู้วา ไปremark ที่ตรงใหนครับ งง ๆ อยู่ หาไม่เจอ
code อันหลังนี้ ทำแล้วใช้ได้
ผมแก้ไปที่ปุ่ม preview ครับ Private Sub Command12_Click() On Error Resume Next Dim stDocName As String DoCmd.SetWarnings False stDocName = "RSPS2A4" DoCmd.OpenReport stDocName, acPreview End Sub
แต่อยากรู้อันแรก ที่ิคุณ badman แจ้งไว้ สงสัย
บอกว่าทำตามวิธีที่สองก็ได้
หรือไม่ก็ ใช้ remark ตรง Msgbox Err.Description (ดังที่ผมremarkไว้ให้ดูครับ)
ตรงนี้ครับ อยากรู้วา ไปremark ที่ตรงใหนครับ งง ๆ อยู่ หาไม่เจอ
6 @R13734
เอาอย่างนี้ครับ
Private Sub Command12_Click()
On Error Resume Next
DoCmd.OpenReport "RSPS2A", acPreview
End Sub
การใส่บรรทัดคำสั่ง On Error Resume Next นั่นคือการ "ดัก" ตามที่ผมให้ความเห็นไปในตอนต้นครับ
ที่อาจารย์ Badman กับ อาจารย์ access hotline (ที่คุณไปอ้างอิงมา) บอกไว้น่ะ สำหรับคนอื่นครับ คือคนที่เขาอยากยืดหยุ่น ว่า บางครั้งต้องการรู้ว่า มีอะไร error เขาจะปล่อยบรรทัดคำสั่ง
msgbox err.description
แต่ถ้าบางคน บางจังหวะ เขาไม่ต้องการให้มันขึ้นคำเตือนใดๆ เขาก็จะเบรคบรรทัดนี้ไว้
แต่ส่วนของคุณ คุณไม่ต้องการ คำเตื่อนใดๆ นอกจาก no data ของคุณเอง และไม่ต้องการจะยืดหยุ่นอะไรอีก ดังนั้น เอาสั้นๆ สองบรรทัดแบบที่ผมให้ไปนั่นเลยครับ
ถ้าตอนนี้ยังงง ยังตามไม่ทัน เอาไว้ก่อน ถ้าเจอมันบ่อยๆ เดี๋ยวจะเริ่มเข้าใจไปเองครับ ไม่ต้องรีบร้อนเข้าใจก็ได้ บางครั้งก็ข้ามๆ มันไปก่อน ให้งานมันลุล่วงไปก่อน ค่อยทำความเข้าใจกับมันทีหลังก็ได้มั้งครับ สู้สู้!
Private Sub Command12_Click()
On Error Resume Next
DoCmd.OpenReport "RSPS2A", acPreview
End Sub
การใส่บรรทัดคำสั่ง On Error Resume Next นั่นคือการ "ดัก" ตามที่ผมให้ความเห็นไปในตอนต้นครับ
ที่อาจารย์ Badman กับ อาจารย์ access hotline (ที่คุณไปอ้างอิงมา) บอกไว้น่ะ สำหรับคนอื่นครับ คือคนที่เขาอยากยืดหยุ่น ว่า บางครั้งต้องการรู้ว่า มีอะไร error เขาจะปล่อยบรรทัดคำสั่ง
msgbox err.description
แต่ถ้าบางคน บางจังหวะ เขาไม่ต้องการให้มันขึ้นคำเตือนใดๆ เขาก็จะเบรคบรรทัดนี้ไว้
แต่ส่วนของคุณ คุณไม่ต้องการ คำเตื่อนใดๆ นอกจาก no data ของคุณเอง และไม่ต้องการจะยืดหยุ่นอะไรอีก ดังนั้น เอาสั้นๆ สองบรรทัดแบบที่ผมให้ไปนั่นเลยครับ
ถ้าตอนนี้ยังงง ยังตามไม่ทัน เอาไว้ก่อน ถ้าเจอมันบ่อยๆ เดี๋ยวจะเริ่มเข้าใจไปเองครับ ไม่ต้องรีบร้อนเข้าใจก็ได้ บางครั้งก็ข้ามๆ มันไปก่อน ให้งานมันลุล่วงไปก่อน ค่อยทำความเข้าใจกับมันทีหลังก็ได้มั้งครับ สู้สู้!
7 @R13737
ขอบคุณครับ
มันยากเหมือนกันสำหรับคนที่ใช้ระบบตัดแปะ
แต่ใช้ได้แล้วครับ
มันยากเหมือนกันสำหรับคนที่ใช้ระบบตัดแปะ
แต่ใช้ได้แล้วครับ
Time: 0.3088s
มันแจ้งเตือนสำหรับคำสั่งก่อนหน้าครับ เช่น
คุณอาจใช้คำสั่งเปิดรายงานนี้มาจาก ปุ่มคำสั่งบนฟอร์มอื่นๆ
หรือคุณเรียกใช้คำสั่งเปิดรายงาน จาก macro
ถ้าคุณจะยกเลิกคำเตือนดังกล่าวต้องไปดักที่คำสั่งเหล่านั้นครับ
เฉพาะที่ตัวรายงานนี้ ไม่ต้องทำอะไรครับ มันปกติดีแล้ว
Private Sub Report_NoData(Cancel As Integer)
MsgBox "No data found! Closing report."
Cancel = True
End Sub