@ ประกาศใช้งานเว็บบอร์ดใหม่คลิกลิ้งได้ที่โลโก้ ไท.Access หรือกด --> บอร์ดเรียนรู้ Access สำหรับคนไทย 
                         โพสต์ถาม,ตอบที่บอร์ดใหม่ แล้วจะใส่ลิ้งอ้างมาที่บอร์ดนี้หรือไม่ก็ตามสะดวกครับ


Access : จุดเริ่มต้นที่ง่ายที่สุดสำหรับการเรียนรู้ ระบบฐานข้อมูล
Access : จุดเริ่มต้นที่ง่ายที่สุดสำหรับการเรียนรู้ การเขียนโปรแกรม
Access : เป็นได้ทั้งตัวเก็บฐานข้อมูล และตัวจัดการฐานข้อมูล
Thai Access : บอร์ดเสริมการเรียนรู้ Access ด้วยภาษาไทย


Back to Board : Thai Access Webboard

ลบข้อมูลในตาราง Subform


Topic by Message Posted : on : 1/9/2552 16:37:06
มือใหม่VB  ถามเรื่องการเขียนCode vb ปุ่มคำสั่ง Delete เพื่อลบข้อมูลในฟอร์มที่ link กับ Subform อยากให้ลบในตารางของ Subform ด้วยต้องทำอย่างไรครับ

11 Reply in this Topic. Dispaly 1 pages and you are on page number 1

Reply by Message on : 1/9/2552 17:12:23
yeadram
(R03163)
currentproject.connection.execute "Delete From table2 where ........."
me.child1.form.requery
Back to Top
Reply by Message on : 4/9/2552 15:52:08
มือใหม่VB
(R03232)
ลองเขียนแล้วไม่ได้ครับ งง
Back to Top
Reply by Message on : 4/9/2552 23:06:27
yeadram
(R03251)
subform ของคุณ มีแหล่งข้อมูลมาจากไหน
ถ้าเป็นตาราง ชื่อตารางอะไร และ subform นี้ใช้ฟิลด์ไหนผูกกับฟอร์มหลัก

ถ้าเป็นคิวรี่ sql มันเป็นอย่างไร ขอดูหน่อยครับ แล้วใช้ฟิลด์ไหนผูกกับตารางหลัก

เราจะสั่งให้มันเขียน statement เพื่อรัน ให้มันลบข้อมูลที่เกี่ยวข้องกับฟอร์มย่อยก่อน
แล้วค่อยสั่งลบข้อมูลเรคคอร์ดนี้ ของฟอร์มหลัก

ปัญหาคือ ในฟอร์มย่อยของคุณมีโครงสร้าง มีแหล่งข้อมูลเป็นอย่างไร ถ้าไม่รู้สิ่งเหล่านั้น เราก็เขียน statement ได้ไม่ถูกต้อง

ผมตอบไปครั้งแรก นึกว่าคุณจะสามารถเอาไปดัดแปลงต่อได้ แต่ถ้าบอกว่า งง ก็คงต้องเริ่มกันใหม่ ช้าๆ ครับ

เวลาถามปัญหาไม่ต้องถามสั้นขนาดนั้นครับ เพราะคนตอบไม่รู้ว่า จะบอกคุณละเอียดมากน้อยแค่ไหนคุณถึงจะเข้าใจ เพราะเราเดาไม่ได้ว่าคุณรู้อะไรแล้วบ้าง จากคำถามของคุณ ใครล่ะจะแน่ใจว่า ไม่ได้เอามะพร้าวห้าวไปขายสวน
Back to Top
Reply by Message on : 11/9/2552 9:09:48
อนุชิต
(R03327)
เรียน คุณมือใหม่ VB
ผมขอตอบคำถามของคุณดังนี้ครับ

ปกติเวลาเราสร้างฟอร์ม โดยมีลักษณะฟอร์มหลัก กับ ฟอร์มย่อย หรือที่เรียกว่า Subform นั้น ปกติถ้าเราดูที่โครงสร้างของแหล่งข้อมูล จะเกิดจากตารางที่มีความสัมพันธ์ซึ่งกันและกันเสมอ

กรณีที่เราลบรายการข้อมูลใน ฟอร์มหลัก โดยทั่วไป ข้อมูลในฟอร์มย่อย ก็จะถูกลบตามไปด้วย โดยอาศัยการตรวจสอบความสอดคล้องกันของข้อมูลระหว่าง 2 ตารางที่มีความสัมพันธ์ซึ่งกันและกัน (Referential Integrity) เราสามารถอาศัยคุณสมบัตินี้ โดยการเลือก Cascade Delete Relate Record ในความสัมพันธ์ระหว่าง 2 ตาราง เวลาคุณลบข้อมูลของฟอร์มหลัก ข้อมูลของฟอร์มย่อยก็จะถูกลบตามไปด้วยครับ
Back to Top
Reply by Message on : 11/9/2552 11:10:03
มือใหม่VB
(R03330)
ผมมีข้อมูลจาก 2 ตารางดังนี้ครับ
ตารางที่ 1
1.1CodeID**
1.2Product
1.3UnitCount
1.4Weight

ตารางที่ 2
2.1CodeID**
2.2Cust
2.3Price
2.4Total
**ใช้CodeID เป็น Relationship ครับ

ผมใช้ตารางที่ 2 เป็น Subform ครับถ้าผมลบข้อมูลในตาราง 1 แล้วอยากให้ข้อมูลในตารางที่ 2 ลบไปด้วยต้องทำเยี่ยงไรครับอาจารย์และท่านผู้รู้ขอCodeคำสั่งด้วยครับ
Back to Top
Reply by Message on : 11/9/2552 13:05:49
yeadram
(R03332)


-ตั้งค่าความสัมพันธ์ให้ได้ดังรูป (สังเกตบริเวณ วงสีแดง)
-เมื่อมีการลบเรคคอร์ดในฟอร์มหลัก ข้อมูลในฟอร์มย่อยจะถูกลบให้โดยอัตโนมัติครับ ไม่ต้องเขียนโค้ดเพิ่มเติมใดๆ ครับ
Back to Top
Reply by Message on : 17/9/2552 17:11:41
มือใหม่VB
(R03408)
ทำแล้วมันมีข้อความขึ้นว่า"No unique index found for the referenced field of the primary table.!"หมายถึงอะไรครับ
Back to Top
Reply by Message on : 17/9/2552 17:33:36
yeadram
(R03409)
1 ตารางฝั่ง one (ฝั่งซ้ายมือตามรูป) จำเป็นต้องมี Primary key
2 ตารางฝั่ง many (ฝั่งขวามือดังรูป) จะมีหรือไม่มี primary ก็ได้ (แต่ก็ควรจะมี)
3 ฟิลด์ที่จะใช้เป็น relation กันในลักษณะ one-to-many ต้อง
    - ฝั่ง one ต้องเป็น primary
    - ฝั่ง many ห้ามเป็น primary

พอผมเขียนโพสต์นี้ ผมได้ย้อนไปดู ข้อความของคุณก่อนหน้านี้ R03330 เท่าที่เดาๆ โครงสร้าง ผมว่าคุณน่าจะออกแบบไม่เหมาะสม
ตารางสองตารางนี้ ทำหน้าที่อะไรกันบ้าง ทำหน้าที่ซ้ำซ้อนกันหรือเปล่า
ตามหลักการของ "การจัดการ" ไม่ว่าจะเป็นการจัดการฐานข้อมูล หรือจะจัดการอะไรก็ตาม) เรากำลังพยามลดความซ้ำซ้อน เพื่ออำนวยความสะดวกให้ความซับซ้อน กล่าวคือ แม้งานจะซับซ้อน แต่เราจะลำดับมัน, แยกกลุ่มมัน, หาความสัมพันธ์มัน เพื่อให้ความซับซ้อนได้ดำเนินไปอย่างเป็นระบบ
    ระบบงานมันต้องมีความซับซ้อนแน่นอนครับ ถ้าไม่ซับซ้อนแนะนำให้ไปใช้ word หรือ excel จะคล่องกว่า เราออกแบบฐานข้อมูล ไม่ได้หมายถึงขจัดความซับซ้อน แต่หมายถึง การจัดการ สิ่งต่างๆ ที่ซับซ้อนเหล่านั้นให้เป็นระบบ ซึ่งการจัดการที่ดี คือ ลดความซ้ำซ้อน ออกไปเป็นอันดับแรกครับ
    ไม่งง นะครับ
     เท่าที่ดู ชื่อฟิลด์ของคุณ เหมือนๆ กับว่า สองตารางนี้ มันทำหน้าที่ซ้ำซ้อนกันหรือเปล่าครับ

- ลองยกตัวอย่าง ข้อมูลดิบ ที่คุณมีในตารางที่ 1 มาสัก 5 รายการ (ทุกฟิลด์)
- ลองยกตัวอย่าง ข้อมูลดับ ในตาราง ที่ 2 มาสัก 5 รายการ (ทุกฟิลด์) ให้ดูได้ไหมครับ
- ลองจับภาพ ความสัมพันธ์ ระหว่างสองตารางนี้ ที่คุณทำไว้ (ภาพเหมือนกับที่ผมทำ) ให้ดูได้ไหมครับ อาจจะบอกได้ว่า ปัญหาของคุณอยู่ที่อะไร
Back to Top
Reply by Message on : 18/9/2552 11:24:13
มือใหม่VB
(R03424)
ผมทำได้แล้วครับ เหมือนที่อาจารย์ yeadram บอกพอดีผมทำ primary key ซ้ำกันตอนออกแบบ relation ตอนนี้สามารถลบได้แล้วครับ ขอบพระคุณทุกท่านที่ช่วยเหลือมือใหม่ครับ
Back to Top
Reply by Message on : 29/3/2555 11:13:04
Longkong
(R12482)
เรียน อาจารย์ yeadram

        ขอรบกวนด้วยค่ะ Delete Record ใน Subform แล้วมันไม่ตรงตามที่เราเลือก มันกลับไป delete record แรกสุดเสมอ

        ดิฉันมี 2 ตาราง ชื่อว่า KPI Question และ KPI Answer ให้ field Item เป็น text ค่ะ ซึ่งทั้ง 2 ตารางนี้ มี field เดียวกันคือ Item
        - KPI Question.Item --> Primary Key
        - KPI Answer.Item --> Index เป็น Yes (No Duplicates)
        ปัญหามีอยู่ว่า ดิฉันสร้าง form ขึ้นมา 1 form ชื่อว่า Main และภายในฟอร์ม Main จะมี Subform ด้วย ในฟอร์ม Main จะมี Item ที่สร้างเป็น Combo Box ให้ drop down list ค่ะ เวลาที่ drop down แล้วจะแสดงข้อมูลใน Subform ทั้งหมด ซึ่งทำได้แล้ว แต่เวลา delete มันกลับ delete record แรกสุดค่ะ ไม่ delete record ที่เรา drop down
        ตัวอย่างเช่น ใน Combo ของ Item ดิฉัน click เลือก 005 มันก็จะดึงข้อมูลของ Subform ออกมาถูกต้อง แล้วดิฉันก็สร้างปุ่ม Delete ตามวิธีการ one-to-many มันก็ delete record ทั้ง KPI Question และ KPI Answer ค่ะ (เกือบถูก) แต่ผิดเนื่องจากว่า มันไปลบ record แรกสุดคือ Item ที่ 001 ค่ะ ไม่ว่าจะเลือก delete record ใดก็ตาม มันก็ไป delete record แรกสุดอีก จนปัญญาค่ะ ขอรบกวนด้วยเถอะค่ะ ขอบคุณอาจารย์มาก ๆ ค่ะ
Back to Top
Reply by Message on : 30/3/2555 10:14:48
yeadram
(R12486)
ในปุ่มคำสั่ง delete record
ต้องใส่เงื่อนไขในการลบด้วยครับ
เขียนคำสั่งเองหรือว่าใช้ วิซาร์ดช่วยสร้างปุ่มครับ

ถ้าเขียนคำสั่งเอง ขอดูคำสั่งหน่อยครับ

ถ้าใช้วิซาร์ดช่วยสร้าง ถามเพิ่มครับ
- ฟอร์มหลักดึงข้อมูลจากตารางชื่ออะไร
- คอมโบที่เลื่อก item ในฟอร์มหลักชื่ออะไร
- คอมโบดังกล่าวใช้ control source คืออะไร ชื่ออะไร (ไม่ใช่ row source นะ คนละอันกัน)
- เมื่อมีการเลือกคอมโบ แล้วฟอร์มย่อยเปลี่ยนแปลงตาม อันนี้ใช้วิซาร์ดช่วยสร้างหรือเขียนคำสั่งเอง
- ฟอร์มหลักกับฟอร์มย่อย มีการใช้ link child field หรือเปล่า ใช้ฟิลด์อะไรเป็นตัวลิงค์
Back to Top

 @ ประกาศใช้งานเว็บบอร์ดใหม่คลิกลิ้งได้ที่โลโก้ ไท.Access หรือกด --> บอร์ดเรียนรู้ Access สำหรับคนไทย 
                         โพสต์ถาม,ตอบที่บอร์ดใหม่ แล้วจะใส่ลิ้งอ้างมาที่โพสต์เก่านี้หรือไม่ก็ตามสะดวกครับ


Sorry, you can NOT post a reply.
+++ webboard source: ASPThai.Net Webboard 6.0 webbord +++++++ admin : yeadram +++