กระทู้เก่าบอร์ด อ.Yeadram
6,647 32
URL.หัวข้อ /
URL
รายงานตามเงื่อนไข
อยากเปิดรายงานตามเงื่อนไข ตามรูปครับ โดยที่
คอมโบ เลือกบริษัท = cbo1
คอมโบ เลือกสาขา = cbo2
คอมโบ เลือกพนักงาน = cbo3
คอมมานด์ เปิดรายงาน = cmdopen
เทกบอกซ์ วันเริ่มต้น = txtstrat
เทกบอกซ์ วันสิ้นสุด = txtend
รายงานจากคิวรี่เดี่ยวกัน ประกอบด้วย
jobid date cus branch service
เงื่อนไข
1. เมื่อเลือก บริษัท ไม่เลือกอย่างอื่น ก็เปิดรายงานเกี่ยวกับบริษัทที่เลือกทั้งหมด
และกรณีเดียวกัน เมื่อเลือก คอมโบอื่น ๆ
2 เมื่อ เลือก 2 คอมโบ ก็ให้เปิดรายงานตามเงือนไขที่เลือก
3 เมื่อเลือกวันที่ ต้องใส่วันที่เริ่มต้น และวันที่สิ้นสุด โดยตรวจสอบคอมโบ ด้านบนว่ามีการเลือกหรือไม่ ถ้าเลือกก็นำมาใส่ในเงือนไขด้วย แล้วเปิดรายงาน
ต้องเขียนโค้ดอย่างไรครับ หรือว่าต้องใช้ อะไรในการต้องการเงือนไขอย่างนี้ครับ
รบกวนด้วยครับ
ขอบคุณครับ
32 Reply in this Topic. Dispaly 2 pages and you are on page number 1
2 @R07456
ลองทำตามแล้วครับ
ได้ผลอย่างนี้ครับ
ช่วยด้วยนะครับ ไม่ทราบจริง ๆ ว่า โค้ดทำงานยังไง มองภาพไม่ออกนะครับ
Private Sub cmdOpenrpt_Click()
Dim stWhere As String
stWhere = "[Ser] Like '*'"
If cbo1 <> "" Then stWhere = stWhere & " AND [JobID] =" & cbo1
If cbo2 <> "" Then stWhere = stWhere & " AND [Branch] = " & cbo2
If cbo3 <> "" Then stWhere = stWhere & " AND [Cus] = " & cbo3
If txtstart <> "" Then
If txtEnd = "" Or txtEnd < txtstart Then
txtEnd.SetFocus
Exit Sub
End If
stWhere = stWhere & " AND ([date] BETWEEN #" & txtstart & "# and #" & txtEnd & "#)"
ElseIf txtEnd <> "" Then
txtstart.SetFocus
Exit Sub
End If
DoCmd.OpenReport "rptJobNo", acViewPreview, , stWhere
End Sub
ข้อมูลการตั้งค่าตาราง
jobid >> text >> 10 FK
date >> date/time >>short date
cus >> text >> 100
branch >> text >> 150
service >> text >> 150
แบบสอบถาม qryjobser
มี 4 ตาราง ประกอบด้วย
job มี Jobid,date
cus เอา idcus เชื่อม เป็นชนิด text
branch เอา idbranch เชื่อม เป็นชนิด number
service เอา idser เชื่อม เป็นชนิด text
ได้ข้อมูล
jobid date idcus cus idbran branch idser service
นำคิวรี่นี้มาทำรายงานครับ
ขอบคุณครับ
ได้ผลอย่างนี้ครับ
ช่วยด้วยนะครับ ไม่ทราบจริง ๆ ว่า โค้ดทำงานยังไง มองภาพไม่ออกนะครับ
Private Sub cmdOpenrpt_Click()
Dim stWhere As String
stWhere = "[Ser] Like '*'"
If cbo1 <> "" Then stWhere = stWhere & " AND [JobID] =" & cbo1
If cbo2 <> "" Then stWhere = stWhere & " AND [Branch] = " & cbo2
If cbo3 <> "" Then stWhere = stWhere & " AND [Cus] = " & cbo3
If txtstart <> "" Then
If txtEnd = "" Or txtEnd < txtstart Then
txtEnd.SetFocus
Exit Sub
End If
stWhere = stWhere & " AND ([date] BETWEEN #" & txtstart & "# and #" & txtEnd & "#)"
ElseIf txtEnd <> "" Then
txtstart.SetFocus
Exit Sub
End If
DoCmd.OpenReport "rptJobNo", acViewPreview, , stWhere
End Sub
ข้อมูลการตั้งค่าตาราง
jobid >> text >> 10 FK
date >> date/time >>short date
cus >> text >> 100
branch >> text >> 150
service >> text >> 150
แบบสอบถาม qryjobser
มี 4 ตาราง ประกอบด้วย
job มี Jobid,date
cus เอา idcus เชื่อม เป็นชนิด text
branch เอา idbranch เชื่อม เป็นชนิด number
service เอา idser เชื่อม เป็นชนิด text
ได้ข้อมูล
jobid date idcus cus idbran branch idser service
นำคิวรี่นี้มาทำรายงานครับ
ขอบคุณครับ
3 @R07457
ตามหาสาเหตุกันครับ
1 ให้คุณเปิดคิวรี่ qryjobser มาดู (โดยไม่ต้องใส่เงื่อนไขใดๆ ทั้งสิ้น) ดูว่ามันถามหา พารามิเตอร์หรือเปล่า
ถ้าถามหาพารามิเตอร์ แสดงว่าคิวรี่มีปัญหา คุณต้องหาทางเอา พารามิเตอร์ตรงนั้นออกก่อน แล้วลองทำงานผ่านฟอร์มดูอีกครั้ง
ถ้าไม่ถาม แสดงว่า ตัวคิวรี่ไม่มีปัญหา ไปทดสอบข้อ2
2 ให้คุณเปิดรายงาน rptJobNo (ดับเบิ้ลคลิ๊กเปิดขึ้นมาเลย ข้อมูลมามากน้อยก็ช่าง) ดูว่ามันมีการถามหาพารามิเตอร์หรือเปล่า
ถ้ามันถาม แสดงว่าตัวรายงานมีปัญหา ให้คุณหาทางเอาพารามิเตอร์เหล่านั้นออกให้ได้ เช่น - มีการ เขียนนิพจน์ผิดๆ ตาม textbox ต่างๆ หรือเปล่า , - มีการตั้งค่าการเรียงลำดับโดยอ้างชื่อผิดหรือเปล่า , - มีการตั้งกลุ่มแล้วอ้างชื่อผิดหรือเปล่า
ถ้ามันไม่ถาม แสดงว่า ตัวรายงานไม่มีปัญหา ให้ไปทดสอบข้อ3
3 สันนิษฐานว่า คุณต่อสายอักขระตัวเงื่อนไข ผิดรูปแบบ
ให้คุณลอง debug ดูสายอักขระดูก่อน
...
...
End If
เพิ่มบรรทัดนี้
debug.print stWhere
เบรคบรรทัดนี้
' DoCmd.OpenReport "rptJobNo", acViewPreview, , stWhere
End Sub
ลองทำงานผ่านฟอร์ม ใส่ข้อมูลตามต้องการ > > กดปุ่มเรียกรายงาน >> กดปุ่ม ctl+G ดูผลการ debug ดูว่ามันเขียนอะไรออกมาบ้าง ลองคัดลอกมาทั้งหมด มาโพสต์ครับ หรือถ้าดูเป็นก็ลองสังเกตเรื่องของชื่อฟิลด์ ชื่อตาราง
ถ้าเป็นชื่อฟิลด์ควรถูกคร่อมด้วยเครื่องหมายวงเล็บสี่เหลี่ยม
ถ้าเป็นตัวเลขไม่ควรถูกคร่อมด้วยเครื่องหมายใดๆ เลยและ operator ต้องเป็นเครื่องหมายเท่ากับเท่านั้น
ถ้าเป็น text จะต้องถูกคร่อมด้วยเครื่องหมาย หยดน้ำค้าง และใช้ opertor Like ไม่ใช่เครื่องหมายเท่ากับ
ถ้าเป็น Date/Time ต้องถูกคร่อมด้วยเครื่องหมายชาร์ฟ ใช้ Operator Between...and...
สุดท้ายขอเพิ่มเติมนิดครับ จากรูปที่นำมาให้ดู ZZ0718 คืออะไรครับ
เป็นชื่อฟิลด์ ชื่อตาราง(ที่คุณไม่ได้บอกมาหรือเปล่า)
หรือว่าเป็นข้อมูล ถ้าเป็นข้อมูล เป็นข้อมูลของฟิลด์อะไรครับ
พารามิเตอร์ตัวนี้ มันขึ้นมาตลอดหรือเปล่า หากว่าคุณได้ลองเลือกเงื่อนไขอื่นๆ ดู มันยังขึ้นตัวนี้หรือว่าเป็นตัวอื่น
1 ให้คุณเปิดคิวรี่ qryjobser มาดู (โดยไม่ต้องใส่เงื่อนไขใดๆ ทั้งสิ้น) ดูว่ามันถามหา พารามิเตอร์หรือเปล่า
ถ้าถามหาพารามิเตอร์ แสดงว่าคิวรี่มีปัญหา คุณต้องหาทางเอา พารามิเตอร์ตรงนั้นออกก่อน แล้วลองทำงานผ่านฟอร์มดูอีกครั้ง
ถ้าไม่ถาม แสดงว่า ตัวคิวรี่ไม่มีปัญหา ไปทดสอบข้อ2
2 ให้คุณเปิดรายงาน rptJobNo (ดับเบิ้ลคลิ๊กเปิดขึ้นมาเลย ข้อมูลมามากน้อยก็ช่าง) ดูว่ามันมีการถามหาพารามิเตอร์หรือเปล่า
ถ้ามันถาม แสดงว่าตัวรายงานมีปัญหา ให้คุณหาทางเอาพารามิเตอร์เหล่านั้นออกให้ได้ เช่น - มีการ เขียนนิพจน์ผิดๆ ตาม textbox ต่างๆ หรือเปล่า , - มีการตั้งค่าการเรียงลำดับโดยอ้างชื่อผิดหรือเปล่า , - มีการตั้งกลุ่มแล้วอ้างชื่อผิดหรือเปล่า
ถ้ามันไม่ถาม แสดงว่า ตัวรายงานไม่มีปัญหา ให้ไปทดสอบข้อ3
3 สันนิษฐานว่า คุณต่อสายอักขระตัวเงื่อนไข ผิดรูปแบบ
ให้คุณลอง debug ดูสายอักขระดูก่อน
...
...
End If
เพิ่มบรรทัดนี้
debug.print stWhere
เบรคบรรทัดนี้
' DoCmd.OpenReport "rptJobNo", acViewPreview, , stWhere
End Sub
ลองทำงานผ่านฟอร์ม ใส่ข้อมูลตามต้องการ > > กดปุ่มเรียกรายงาน >> กดปุ่ม ctl+G ดูผลการ debug ดูว่ามันเขียนอะไรออกมาบ้าง ลองคัดลอกมาทั้งหมด มาโพสต์ครับ หรือถ้าดูเป็นก็ลองสังเกตเรื่องของชื่อฟิลด์ ชื่อตาราง
ถ้าเป็นชื่อฟิลด์ควรถูกคร่อมด้วยเครื่องหมายวงเล็บสี่เหลี่ยม
ถ้าเป็นตัวเลขไม่ควรถูกคร่อมด้วยเครื่องหมายใดๆ เลยและ operator ต้องเป็นเครื่องหมายเท่ากับเท่านั้น
ถ้าเป็น text จะต้องถูกคร่อมด้วยเครื่องหมาย หยดน้ำค้าง และใช้ opertor Like ไม่ใช่เครื่องหมายเท่ากับ
ถ้าเป็น Date/Time ต้องถูกคร่อมด้วยเครื่องหมายชาร์ฟ ใช้ Operator Between...and...
สุดท้ายขอเพิ่มเติมนิดครับ จากรูปที่นำมาให้ดู ZZ0718 คืออะไรครับ
เป็นชื่อฟิลด์ ชื่อตาราง(ที่คุณไม่ได้บอกมาหรือเปล่า)
หรือว่าเป็นข้อมูล ถ้าเป็นข้อมูล เป็นข้อมูลของฟิลด์อะไรครับ
พารามิเตอร์ตัวนี้ มันขึ้นมาตลอดหรือเปล่า หากว่าคุณได้ลองเลือกเงื่อนไขอื่นๆ ดู มันยังขึ้นตัวนี้หรือว่าเป็นตัวอื่น
4 @R07458
ข้อ1 เปิดได้ปกติครับ
ข้อ2 รันรายงานได้ปกติครับ
ส่วน ZZ0718 เป็นรหัสบริษัทครับ
หลังจากเพิ่มโค้ดแล้วทำตาม ข้อ3
ที่ หลัง = DD001 เป็น idcus รหัสของบริษัท ครับ
cbo1 ผมดึงมาจากตาราง cus
cbo2 ผมดึงมาจากตาราง branch
cbo3 ผมดึงมาจากตาราง service
รบกวนด้วยครับ
ขอบคุณครับ
ข้อ2 รันรายงานได้ปกติครับ
ส่วน ZZ0718 เป็นรหัสบริษัทครับ
หลังจากเพิ่มโค้ดแล้วทำตาม ข้อ3
ที่ หลัง = DD001 เป็น idcus รหัสของบริษัท ครับ
cbo1 ผมดึงมาจากตาราง cus
cbo2 ผมดึงมาจากตาราง branch
cbo3 ผมดึงมาจากตาราง service
รบกวนด้วยครับ
ขอบคุณครับ
5 @R07460
จากรูป [JobId] = DD001
ต้องเปลี่ยนเป็น [JobID] Like 'DD001'
DD001 มันเป็น text ไม่ใช่ number ต้องใช้ operator Like ส่วนข้อมูลทีมาเปรียบเทียบต้องคร่อมด้วย หยดน้ำค้าง
เพราะฉะนั้นในโค้ดจากปกติ
If cbo1 <> "" Then stWhere = stWhere & " AND [JobID] =" & cbo1
คุณก็ต้องเปลี่ยนเป็น
If cbo1 <> "" Then stWhere = stWhere & " AND [JobID] Like '" & cbo1 & "'"
ลองทำดูอีกทีครับ (ปล่อยบรรทัดที่เบรคไว้แล้วลองสั่งทำงาน) ถ้ายังไม่ได้ส่งไฟล์เข้า gmail มาครับ เดี๋ยวดูให้
ต้องเปลี่ยนเป็น [JobID] Like 'DD001'
DD001 มันเป็น text ไม่ใช่ number ต้องใช้ operator Like ส่วนข้อมูลทีมาเปรียบเทียบต้องคร่อมด้วย หยดน้ำค้าง
เพราะฉะนั้นในโค้ดจากปกติ
If cbo1 <> "" Then stWhere = stWhere & " AND [JobID] =" & cbo1
คุณก็ต้องเปลี่ยนเป็น
If cbo1 <> "" Then stWhere = stWhere & " AND [JobID] Like '" & cbo1 & "'"
ลองทำดูอีกทีครับ (ปล่อยบรรทัดที่เบรคไว้แล้วลองสั่งทำงาน) ถ้ายังไม่ได้ส่งไฟล์เข้า gmail มาครับ เดี๋ยวดูให้
6 @R07461
ผมส่งไฟล์เข้าไปในเมลล์แล้วนะครับ อยู่ในจดหมายร่าง ครับ
รบกวนด้วยครับ
ขอบคุณครับ
รบกวนด้วยครับ
ขอบคุณครับ
7 @R07464
ดูเมล์แล้วครับ
เป็นไฟล์ Access เวอร์ชั่น 2007
รบกวนท่านอื่นๆ ที่มี access เวอร์ชั่นนี้ ช่วยโหลดไฟล์ไปดูให้ด้วยครับ
ผมไม่มี Access เวอร์ชั่นนี้ครับ
เป็นไฟล์ Access เวอร์ชั่น 2007
รบกวนท่านอื่นๆ ที่มี access เวอร์ชั่นนี้ ช่วยโหลดไฟล์ไปดูให้ด้วยครับ
ผมไม่มี Access เวอร์ชั่นนี้ครับ
8 @R07465
ขออนุญาต นำไฟล์ของคุณ saknoi มาแปลงให้เป็นเวอร์ชั่น 2003 แล้วค่ะ ส่งไปไว้ที่เดิม ในหัวข้อ " แปลงไฟล์ Jobservice เป็น 2003 "
อาจารย์ yeadram ลองนำไปทดสอบดูใหม่นะคะ
อาจารย์ yeadram ลองนำไปทดสอบดูใหม่นะคะ
9 @R07466
ขอบคุณ คุณมาลีครับ
ตอบคุณ saknoi ครับ ตอนผมให้โค้ดไป ผมบอกแล้วว่าให้สำรวจชื่อออปเจคต่างๆ ให้ดี ชื่อฟิลด์ ชื่อตารางน่ะครับ คุณไม่ได้แก้ไขโค้ดเลย คุณเอาที่ผมเขียนให้ ไปใช้เลยทันที มันก็เจ๊งซิครับ
เหมือนคุณไปสั่งให้ "จงหาชนิดสัตว์ที่ชื่อ มังคุด" มันจะมีไหมล่ะ
"จงหารุ่นรถถังที่ชื่อ โบอิ้ง747" มันจะมีไหมล่ะ
คุณนำของผมไปใช้ทันทีเลยแบบนี้
แต่ไปดูค่าข้อมูลของคอมโบของคุณ จริงๆ แล้วมันเกี่ยวข้องกับฟิลด์อื่นต่างหาก มันไม่ได้ถูกซักตัวเลย งานของคุณ คอมโบของคุณ โค้ดของคุณมันต้องออกมาเป็นชื่อฟิลด์พวกนี้ ถึงจะถูก (กลับไปดูดีๆ)
สิ่งที่คุณเห็นหน้าจอ ที่คอมโบน่ะ มันใช่ มันเป็นชื่อคน แต่คอมโบของคุณคุณที่เป็น 2-3 ฟิลด์ ค่าที่คอมโบมันเก็บได้มาน่ะ มันไม่ใช่ชื่อคน มันเป็นรหัสของคน
ย้ำ มันเก็บ"รหัส" มันไม่ได้เก็บ "ชื่อ" (คุณออกแบบคอมโบมาแบบนี้) เพราะฉะนั้นเวลานำข้อมูลไปเปรียบเทียบ ก็ต้องเอารหัสไปเปรียบไม่ใช่เอาชื่อไปเปรียบครับ
ต้องทำความเข้าใจกับมันดีๆ ครับ
ตอบคุณ saknoi ครับ ตอนผมให้โค้ดไป ผมบอกแล้วว่าให้สำรวจชื่อออปเจคต่างๆ ให้ดี ชื่อฟิลด์ ชื่อตารางน่ะครับ คุณไม่ได้แก้ไขโค้ดเลย คุณเอาที่ผมเขียนให้ ไปใช้เลยทันที มันก็เจ๊งซิครับ
เหมือนคุณไปสั่งให้ "จงหาชนิดสัตว์ที่ชื่อ มังคุด" มันจะมีไหมล่ะ
"จงหารุ่นรถถังที่ชื่อ โบอิ้ง747" มันจะมีไหมล่ะ
คุณนำของผมไปใช้ทันทีเลยแบบนี้
If cbo1 <> "" Then stWhere = stWhere & " AND [JobID] Like '" & cbo1 & "'"
If cbo2 <> "" Then stWhere = stWhere & " AND [BraName] Like '" & cbo2 & "'"
If cbo3 <> "" Then stWhere = stWhere & " AND [CusName] Like '" & cbo3 & "'"
แต่ไปดูค่าข้อมูลของคอมโบของคุณ จริงๆ แล้วมันเกี่ยวข้องกับฟิลด์อื่นต่างหาก มันไม่ได้ถูกซักตัวเลย งานของคุณ คอมโบของคุณ โค้ดของคุณมันต้องออกมาเป็นชื่อฟิลด์พวกนี้ ถึงจะถูก (กลับไปดูดีๆ)
If cbo1 <> "" Then stWhere = stWhere & " AND [cusID] Like '" & cbo1 & "'"
If cbo2 <> "" Then stWhere = stWhere & " AND [BraID] Like '" & cbo2 & "'"
If cbo3 <> "" Then stWhere = stWhere & " AND [ServiceID] Like '" & cbo3 & "'"
สิ่งที่คุณเห็นหน้าจอ ที่คอมโบน่ะ มันใช่ มันเป็นชื่อคน แต่คอมโบของคุณคุณที่เป็น 2-3 ฟิลด์ ค่าที่คอมโบมันเก็บได้มาน่ะ มันไม่ใช่ชื่อคน มันเป็นรหัสของคน
ย้ำ มันเก็บ"รหัส" มันไม่ได้เก็บ "ชื่อ" (คุณออกแบบคอมโบมาแบบนี้) เพราะฉะนั้นเวลานำข้อมูลไปเปรียบเทียบ ก็ต้องเอารหัสไปเปรียบไม่ใช่เอาชื่อไปเปรียบครับ
ต้องทำความเข้าใจกับมันดีๆ ครับ
10 @R07472
ขอบคุณอาจารย์ yeadram มากเลยครับ
ที่ช่วยชี้แนะ และแก้ไข ตอนนี้ สามารถนำโค้ดที่อาจารย์ ให้มานำมาใช้ได้แล้วครับ
ขอบคุณมากครับ
ปล. ขอบคุณ คุณมาลี ที่ช่วยแปลงไฟล์ให้ด้วยนะครับ
ที่ช่วยชี้แนะ และแก้ไข ตอนนี้ สามารถนำโค้ดที่อาจารย์ ให้มานำมาใช้ได้แล้วครับ
ขอบคุณมากครับ
ปล. ขอบคุณ คุณมาลี ที่ช่วยแปลงไฟล์ให้ด้วยนะครับ
11 @R07647
แนะนำหน่อยครับ
ไม่ทราบว่า มันมีปัญหาที่ตรงไหนครับ
ตอนนี้ผมคีย์ข้อมูลไปได้ประมาณ 50 เรคคอร์ด แล้วมีปัญหาครับ
เมื่อผมเลือก ช่วงวันที่
txtstart กับ txtend แล้ว รายงานเปิดหน้าว่าง ๆ ขึ้นมาครับ ลองเปลี่ยนรูปแบบวันที่ค้นหาแล้ว ก็ยังไม่เจอครับ
พอใส่เงื่อนไข เฉพาะวันที่ก็ไม่สามารถหาค่าที่ต้องการได้ ทั้งที่ค่าระหว่างวันที่ ที่คีย์ไปนั้นมีในตารางนะครับ
แต่ถ้าใส่เงือนไขอื่น ๆ ก็เปิดรายงานได้ปกติ ครับ แต่ห้ามใส่ช่วงวันที่เท่านั้นเอง
และอีกไฟล์นะครับ
เมื่อใส่ช่วงวันที รายงานจะแสดงวันที่ ที่คีย์ไปจนถึงวันที่น้อยที่สุดนะครับ
ตัวอย่าง ตารางผมมี ข้อมูล ตั้งแต่ 1/2/2010 -31/7/2010
เมื่อใส่ช่วงเวลา 1/5/2010-31/5/2010 กดเปิดรายงาน
รายงานจะโชว์ข้อมูล ตั้งแต่ 31/5/2010-1/2/2010 เลยครับ
โค้ดที่ใช้ก็ใช้โค้ดตัวเดี่ยวกันครับ ข้อมูลเดี่ยวกัน
เครื่องเดี่ยวกัน และลองกับเครื่องอื่นได้ผลเหมือนกันครับ
รบกวนด้วยนะครับ
ขอบคุณครับ
ไม่ทราบว่า มันมีปัญหาที่ตรงไหนครับ
ตอนนี้ผมคีย์ข้อมูลไปได้ประมาณ 50 เรคคอร์ด แล้วมีปัญหาครับ
เมื่อผมเลือก ช่วงวันที่
txtstart กับ txtend แล้ว รายงานเปิดหน้าว่าง ๆ ขึ้นมาครับ ลองเปลี่ยนรูปแบบวันที่ค้นหาแล้ว ก็ยังไม่เจอครับ
พอใส่เงื่อนไข เฉพาะวันที่ก็ไม่สามารถหาค่าที่ต้องการได้ ทั้งที่ค่าระหว่างวันที่ ที่คีย์ไปนั้นมีในตารางนะครับ
แต่ถ้าใส่เงือนไขอื่น ๆ ก็เปิดรายงานได้ปกติ ครับ แต่ห้ามใส่ช่วงวันที่เท่านั้นเอง
และอีกไฟล์นะครับ
เมื่อใส่ช่วงวันที รายงานจะแสดงวันที่ ที่คีย์ไปจนถึงวันที่น้อยที่สุดนะครับ
ตัวอย่าง ตารางผมมี ข้อมูล ตั้งแต่ 1/2/2010 -31/7/2010
เมื่อใส่ช่วงเวลา 1/5/2010-31/5/2010 กดเปิดรายงาน
รายงานจะโชว์ข้อมูล ตั้งแต่ 31/5/2010-1/2/2010 เลยครับ
โค้ดที่ใช้ก็ใช้โค้ดตัวเดี่ยวกันครับ ข้อมูลเดี่ยวกัน
เครื่องเดี่ยวกัน และลองกับเครื่องอื่นได้ผลเหมือนกันครับ
รบกวนด้วยนะครับ
ขอบคุณครับ
12 @R07655
ไฟลแรกแก้ไขได้แล้วครับ แต่มีปัญหาเหมือนไฟล์ที่ 2 ครับ
เมื่อใส่ช่วงวันที่ เช่น 1/5/2010-31/5/2010 รายงานจะแสดงข้อมูล
ตั้งแต่ 31/5/2010 จนถึงวันที่ 1/2/2010 ครับ
ไม่ทราบว่ามันเป็นเพราะอะไรครับ
ในคิวรี่ ผมลองไปใส่ between แล้วก็สามารถเลือกได้ตาที่ต้องการนะครับ
แต่ใส่ โค้ดแล้วผลไม่ได้ตามต้องการครับ
รบกวนด้วยนะครับ
ขอบคุณครับ
เมื่อใส่ช่วงวันที่ เช่น 1/5/2010-31/5/2010 รายงานจะแสดงข้อมูล
ตั้งแต่ 31/5/2010 จนถึงวันที่ 1/2/2010 ครับ
ไม่ทราบว่ามันเป็นเพราะอะไรครับ
ในคิวรี่ ผมลองไปใส่ between แล้วก็สามารถเลือกได้ตาที่ต้องการนะครับ
แต่ใส่ โค้ดแล้วผลไม่ได้ตามต้องการครับ
รบกวนด้วยนะครับ
ขอบคุณครับ
13 @R07665
ลองอันนี้ดูครับ
DoCmd.OpenReport "ชื่อReport", acViewPreview, "Date Between Forms!ชื่อฟอร์ม.txtstrat and Forms!ชื่อฟอร์ม.txtend"
จริงๆแล้วไม่น่านำชื่อ Date มาเป็นชื่อ field เลยนะ
ปัญหาอีกอย่างที่เคยพบคือระบบวันที่ ถ้าเป็นระบบวันที่ไทยก็จะมีปัญหาสำหรับ code ตัวนี้ (แต่ไม่มีปัญหาเมื่อใช้กับ query) ซึ่งก็ไม่เข้าใจเหมือนกัน
DoCmd.OpenReport "ชื่อReport", acViewPreview, "Date Between Forms!ชื่อฟอร์ม.txtstrat and Forms!ชื่อฟอร์ม.txtend"
จริงๆแล้วไม่น่านำชื่อ Date มาเป็นชื่อ field เลยนะ
ปัญหาอีกอย่างที่เคยพบคือระบบวันที่ ถ้าเป็นระบบวันที่ไทยก็จะมีปัญหาสำหรับ code ตัวนี้ (แต่ไม่มีปัญหาเมื่อใช้กับ query) ซึ่งก็ไม่เข้าใจเหมือนกัน
14 @R07667
ขอบคุณ คุณNova มากครับ
นำไปใช้กับโค้ดเดิมได้ตามต้องการเลยครับ
นำไปใช้กับโค้ดเดิมได้ตามต้องการเลยครับ
15 @R07689
สอบถามหน่อย ครับ ตรงตัวแปล stwhere = นี่เท่ากับอะไร คับ ชื่อฟอร์มหรือว่า ชื่อรายงานครับ
16 @R07696
เป็นตัวแปลที่ประกาศ ที่กระทู้ (R07454) ครับร
17 @R07697
stwhere = "[ชื่อพนักงาน]" like '*'"
ประมาณนีัครับ
ประมาณนีัครับ
18 @R07701
มันคือ อ๊อบเจ็ค อะไร ครับ หรือ ว่ามัน อยู่ใน รายงาน
งานที่ ผมทำเป็นประมาณ นี้ คือ เลือก ช่วงวัน เเละ มีเงื่อนไข สอง สาม อย่าง แต่ พอใส่ค่าไม่ ครบ มันโชว์ รายงาน หน้าขาว คับ ผมใช้ มาโคร ตามโค้ดนี้ครับ
[date start] Between [Forms]![frmreport]![t39] And [Forms]![frmreport]![t41] And [equipment]=[Forms]![frmreport]![cb33] And [EQ no]=[Forms]![frmreport]![cb35] And [station]=[Forms]![frmreport]![cb31]
งานที่ ผมทำเป็นประมาณ นี้ คือ เลือก ช่วงวัน เเละ มีเงื่อนไข สอง สาม อย่าง แต่ พอใส่ค่าไม่ ครบ มันโชว์ รายงาน หน้าขาว คับ ผมใช้ มาโคร ตามโค้ดนี้ครับ
[date start] Between [Forms]![frmreport]![t39] And [Forms]![frmreport]![t41] And [equipment]=[Forms]![frmreport]![cb33] And [EQ no]=[Forms]![frmreport]![cb35] And [station]=[Forms]![frmreport]![cb31]
19 @R07702
Sub cmdOpen_click()
Dim stWhere as string
stWhere = "[station] Like '*'"
if cb33<>"" then stWhere = stWhere & " AND [equipment] =" & cb33
if cb35 <> "" then stWhere = stWhere & " AND [EQ no] = " & cb35
if cb31 <> "" then stWhere = stWhere & " AND [station] = " & cb31
if t39 <> "" then
if t41 = "" or t41 < t39 then
t41.setfocus
exit sub
end if
stWhere = stWhere & " AND ([DATE] BETWEEN forms!frmreport.t39 and forms!frmreport.t41)"
elseif t41 <> "" then
t39.setfocus
exit sub
end if
DoCmd.OpenReport "report 's name", acViewPreview, , stWhere
end sub
ลองใส่โค้ดนี้ดูครับ
Dim stWhere as string
stWhere = "[station] Like '*'"
if cb33<>"" then stWhere = stWhere & " AND [equipment] =" & cb33
if cb35 <> "" then stWhere = stWhere & " AND [EQ no] = " & cb35
if cb31 <> "" then stWhere = stWhere & " AND [station] = " & cb31
if t39 <> "" then
if t41 = "" or t41 < t39 then
t41.setfocus
exit sub
end if
stWhere = stWhere & " AND ([DATE] BETWEEN forms!frmreport.t39 and forms!frmreport.t41)"
elseif t41 <> "" then
t39.setfocus
exit sub
end if
DoCmd.OpenReport "report 's name", acViewPreview, , stWhere
end sub
ลองใส่โค้ดนี้ดูครับ
20 @R07711
ตอนนี้ผมลองนำ โค้ดที่ให้มาไปใส่แล้ว และ แก้ไขชื่อ อ๊อบเจ็ค ตามโค้ดเเล้ว ครับ สามารถ ทำงานได้ในส่วนของ Date และ NO. ครับ ส่วน ถ้าใส่ ค่า ในช่อง Station หรือ Equipment จะขึ้นถามหา พารามิเตอร์ครับ เช่น ใส่คำว่า RPR มันก็จะให้ใส่ค่าพารามิเตอร์ RPR ครับ ผมลองเช็ค ตาม ข้าง ต้น ดูเเล้ว ก็ยัง หาไม่เจอ ครับ ยังไง รบกวนช่วยเเนะนำ ด้วย ครับ
Time: 0.2912s
อย่างน้อยต้องสำรวจชื่อออบเจคต่างๆ และดูชนิดข้อมูลของแต่ละข้อมูลก่อนด้วย ว่าเป็น text หรือ number หรือ date/time
Sub cmdOpen_click()
Dim stWhere as string
stWhere = "[service] Like '*'"
if cbo1<>"" then stWhere = stWhere & " AND [jobid] =" & cbo1
if cbo2 <> "" then stWhere = stWhere & " AND [branch] = " & cbo2
if cbo3 <> "" then stWhere = stWhere & " AND [cus] = " & cbo3
if txtstart <> "" then
if txtend = "" or txtend < txtstart then
txtend.setfocus
exit sub
end if
stWhere = stWhere & " AND ([date] BETWEEN #" & txtstart & "# and #" & txtend & "#)"
elseif txtend <> "" then
txtstart.setfocus
exit sub
end if
DoCmd.OpenReport "report 's name", acViewPreview, , stWhere
end sub