ProjectForStudy

 ลืมรหัสผ่าน
 ลงทะเบียน
ค้นหา
ดู: 87|ตอบกลับ: 3

[แบ่งปัน] C# การค้นหาข้อมูลใน DataGridView โดยใช้ BindingSource

[คัดลอกลิงก์]
  • อารมณ์วันนี้
    แฮปปี้
    เมื่อวาน 07:47
  • เช็คชื่อแล้ว: 248 วัน

    [LV.8]ConquerorI

    20

    กระทู้

    519

    โพสต์

    1637

    เครดิต

    HawkBrain

    Rank: 4

    เครดิต
    1637
    Ticket
    1125
    จิตพิสัย
    512

    Merciful MemberInstructor

    สวัสดีทุกท่าน ผมขอแบ่งปันวิธีการค้นหาข้อมูลใน DataGridView โดยใช้ BindingSource


    โดยปกติการค้นหาทั่วไปก็จะเขียน ดังนี้
    1. รับค่าพารามิเตอร์การค้นหาใน Textbox
    2. ส่งต่อให้ Sql command string
    3. เปิดการเชื่อมต่อฐานข้อมูล
    4. ทำการ Query ฐานข้อมูล
    5. ส่งกลับมาแสดงใน DataGridView ผ่าน Datasource

    ที่สำคัญถ้าเราเขียนไว้ใน Event TextChanged หละก็ติดต่อฐานข้อมูลทุกครั้งที่มีการพิมพ์ตัวอักษร

    ซึ่งวิธีนี้ ถ้าเป็นการใช้งาน 1 เครื่อง หรือระบบไม่ใหญ่มาก จะไม่พบเท่าไหร่
    แต่ถ้าเป็น ระบบขนาดกลาง หรือใหญ่ เช่น มีเครื่องใช้งาน 50 เครื่องขึ้นไป
    หากทำการค้นหาข้อมูลพร้อมกัน มีโอกาสล่มสูง เนื่องจาก
    1. Server ทำงานหนัก (ต้องทำงานตลอดทุกครั้งที่ค้นหา)
    2. ระบบเน็ตเวิร์ก (คล้าย ๆ กับการจารจร บนถนนที่มีรถติด เพราะมีการใช้ตลอด หรือไม่ก็ต้องเพิ่ม network bandwidth ต้องลงทุนอีกแล้ว)

    ทั้งนี้ขึ้นอยู่กับการออกแบบการเขียนโปรแกรมของเราเหมือนกันที่มีผลต่อ Server หรือ Network system
    ซึ่งตัวอย่างโปรแกรมที่ผมจะนำเสนอวิธีคิดอีกรูปแบบ คือ
    1. โหลดข้อมูลเข้ามา ให้กับ DataSet หรือ DataTable
    2. ส่งข้อมูลให้กับ BindingSource
    3. ใช้คุณสมบัติของ BindingSource ที่มี Filter เป็นตัวค้นหาข้อมูลและแสดงผลใน DataGridView แทน
    ถึงแม้จะสั่งให้โค้ดทำงานใน Event TextChanged เป็นร้อยครั้ง แต่การดึงข้อมูลจากฐานข้อมูลเกิดขึ้นเพียงครั้งแรกครั้งเดียว
    เพราะทุกครั้งที่จะค้นหาข้อมูล จะถูกค้นหาจาก BindingSource แทนฐานข้อมูล

    ซึ่งข้อดีของมันก็คือ
    1. ช่วยลดภาระการทำงานของ Server ลง
    2. ในเมื่อ Server ทำงานน้อยลง ส่งผลทำให้ Network system ก็ไม่ติดขัดตามไปด้วย

    ส่วนข้อเสียคือ
    ไม่เหมาะสำหรับฐานข้อมูลที่มีความถี่ Transaction สูง ที่มีการเพิ่ม ลบ แก้ไขอยู่ตลอดเวลา (ในระดับ วินาที หรือนาที เป็นต้น)

    ตัวอย่างโปรแกรม (ค้นหาผ่าน BindingSource)









    ท่านสามารถดาว์นโหลดตัวอย่างโปรแกรมได้ที่นี่
    ผู้เข้าชมเนื้อหาถูกซ่อนไว้ คุณจะต้องแสดงความคิดเห็นก่อนจึงจะสามารถมองเห็นเนื้อหาส่วนที่ถูกซ่อนนี้ได้



    ขออภัย! โพสต์นี้มีไฟล์แนบหรือรูปภาพที่ไม่ได้รับอนุญาตให้คุณเข้าถึง

    คุณจำเป็นต้อง ลงชื่อเข้าใช้ เพื่อดาวน์โหลดหรือดูไฟล์แนบนี้ คุณยังไม่มีบัญชีใช่ไหม? ลงทะเบียน

    x
  • อารมณ์วันนี้
    สู้
    7 วันที่แล้ว
  • เช็คชื่อแล้ว: 58 วัน

    [LV.5]JuniorI

    0

    กระทู้

    69

    โพสต์

    119

    เครดิต

    BabyGhost

    Rank: 1

    เครดิต
    119
    Ticket
    107
    จิตพิสัย
    12
    maphone12 โพสต์ 2019-5-7 13:58:40 | ดูโพสต์ทั้งหมด
    ขอบคุญ
  • อารมณ์วันนี้
    สู้
    2019-5-7 15:28
  • เช็คชื่อแล้ว: 3 วัน

    [LV.2]BeginnerI

    0

    กระทู้

    8

    โพสต์

    11

    เครดิต

    BabyGhost

    Rank: 1

    เครดิต
    11
    Ticket
    8
    จิตพิสัย
    3
    sonicroute โพสต์ 2019-5-7 15:34:40 | ดูโพสต์ทั้งหมด

    ขอบคุณครับ
  • อารมณ์วันนี้
    แฮปปี้
    2019-5-8 12:18
  • เช็คชื่อแล้ว: 3 วัน

    [LV.2]BeginnerI

    1

    กระทู้

    5

    โพสต์

    2

    เครดิต

    BabyGhost

    Rank: 1

    เครดิต
    2
    Ticket
    0
    จิตพิสัย
    2
    evilkjpat โพสต์ 2019-5-8 12:20:56 | ดูโพสต์ทั้งหมด
    เข้ามาศึกษา ขอบคุณครับ
    ขออภัย! คุณไม่ได้รับสิทธิ์ในการดำเนินการในส่วนนี้ กรุณาเลือกอย่างใดอย่างหนึ่ง ลงชื่อเข้าใช้ | ลงทะเบียน

    รายละเอียดเครดิต

    ข้อความล้วน|อุปกรณ์พกพา|ประวัติการแบน|ProjectForStudy  

    GMT+7, 2019-5-24 03:46 , Processed in 0.054276 second(s), 26 queries .

    Powered by Discuz! X3.2 R20150609, Rev.38

    © 2001-2013 Comsenz Inc.

    ตอบกระทู้ ขึ้นไปด้านบน ไปที่หน้ารายการกระทู้