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,027

HOME > .NET Framework > Forum > สอบถามขอความช่วยเหลือครับ ปัญหาการค้นหาข้อมูลออกมาแสดงช้ามากครับ เงื่อนไขอยากได้แบบ AutoComplete ภาษา C# ครับ



 

สอบถามขอความช่วยเหลือครับ ปัญหาการค้นหาข้อมูลออกมาแสดงช้ามากครับ เงื่อนไขอยากได้แบบ AutoComplete ภาษา C# ครับ

 



Topic : 129459



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



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



Code ในการค้นหาข้อมูลซึ่งมีจำนวนประมาณ 3 แสนกว่า Record ครับ ปัญหาคือมันนำข้อมูลออกมาแสดงช้ามากครับ
พอจะมีวิธีไหนที่ทำให้ไวขึ้นบ้างครับ ช่วยแนะนำและขอตัวอย่างหน่อยครับ

Code (C#)
private void Checkdata(KeyEventArgs e)
        {
            string word=e.KeyData.ToString();
            int cInt = Convert.ToInt32(e.KeyData);

            //MessageBox.Show(cInt);
            if ((int)cInt >= 48 || (int)cInt > 57 && cInt != 8)
            {
                string sql = "SELECT concat(pname,fname,' ',lname) as FullName,patient_hn,cid FROM person where fname like '" + txtSearch.Text + "%' or lname like '%"+ txtSearch.Text + "'group by cid order by fname Limit 5";
                MySqlConnection con = new MySqlConnection(conHos);
                MySqlCommand cmd = new MySqlCommand(sql, con);
                con.Open();
                DataSet ds = new DataSet();
                MySqlDataAdapter da = new MySqlDataAdapter(cmd);
                da.Fill(ds);
                dataGridView1.DataSource = ds.Tables[0].DefaultView;
                //dataGridView1.DataSource = ds.Tables[0];
                con.Close();
            }
        }


ขอบคุณครับ



Tag : MySQL, Win (Windows App), C#







Move To Hilight (Stock) 
Send To Friend.Bookmark.
Date : 2017-11-11 15:15:22 By : stanly View : 891 Reply : 7
 

 

No. 1



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

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

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

มันช้าแน่นอนครับ เพราะดูจากวิธีแล้ว คุณน่าจะใช้พวก Keydown แล้วก็ส่งไปค้นหาข้อมูล ซึ่งมันก็จะช้า แน่นอนเมื่อ User พิมพ์ คีย์ Word เข้าไป มันก็จะทำงานทุกๆ ตัวอักษร

วิธีคือแก้ปัญหา
ดักจับ Keyboard เช่น ถ้า User หยุดการคีย์ซะ 2-3 วินาที ค่อยไปดึงข้อมูลครับ






แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2017-11-14 11:46:45 By : mr.win
 


 

No. 2



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



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


ลองให้ index กับ data field ที่ค้นหาดูครับ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2017-11-15 04:34:47 By : bigsuntat
 

 

No. 3



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



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

1. ดู spec server cpu+ram มีผลในการประมวลผล
2. จัดทำ index ใน filed ที่ต้องทำการค้นหา index ช่วยได้เยอะครับ ระบบใหญ่ ๆ ไฟล์ index ใช้พื้นที่มากกว่า data ซะอีก แต่ก็ต้องทำครับ
3. ตั้งข้อกำหนดคีย์เวิร์ด เช่น ต้อง 3 ตัวอักษร ถึงทำการค้นหา เพื่อกรองข้อมูลให้ส่งกลับเท่าที่จำเป็นครับ ไม่งั้น user คีย์แค่ "ก" กลายเป็นว่าข้อมูลที่ส่งกลับมาจำนวนมากกว่าที่จำเป็น หรือกำหนดให้ต้องใส่รายละเอียดเพิ่มเช่น หาจากแผนกไหนครับ ไม่งั้นทำงานระบบที่ข้อมูลจำนวนมากยังไงก็ช้าครับ
4. ? ทำไมต้อง group by cid ครับ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2017-11-15 10:25:56 By : pison1998
 


 

No. 4



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



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


งงตรง group by cid จำเป็นต้องมีหรือเปล่า
และ cid นี่เป็น unique/primary หรือเปล่า
----------------------------------------------------------------------
คำสั่ง group by นี่เป็นคำสั่งที่ช้ามาก ถ้าไม่มี index เพราะมันจะ สร้าง temporary index ก่อนทำงาน
order by fname ได้จัดทำ index สำหรับ fname หรือเปล่า
----------------------------------------------------------------------
field ไหนสามารถ รวมแล้วค้นหาร่วมกันได้รวมซะก่อน เปรียบเทียบ
where concat( fname,' ',lname) like '%searchtext%' แบบนี้จะเร็วกว่าแยกเปรียบเทียบแต่ละ field
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2017-11-15 11:30:34 By : Chaidhanan
 


 

No. 5



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



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

ตอบความคิดเห็นที่ : 4 เขียนโดย : Chaidhanan เมื่อวันที่ 2017-11-15 11:30:34
รายละเอียดของการตอบ ::
ผมใช่ Evernt Keydown ครับ จำเป็นต้องใช้ Group By CID ครับ เพราะเวลาคนที่ชื่อเหมือนกัน จะได้ดึงมาเฉพาะ Cid ที่ไม่ช้ำกันครับ

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2017-11-16 21:50:31 By : stanly
 


 

No. 6



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



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


พอมีการเพิ่มการคีย์ ให้เรียกมาแสดงแค่ 10 record
พอจัดการเพิ่ม list เสร็จก็ ส่งไปเรียกมาแสดงเพิ่ม ทีละ 10 record จดหมด
เพื่อให้การแสดงผลรื่นไหล และอย่าลืมตรวจสอบว่ามีการคีย์เพิ่มข้อมูลใหม่หรือไม่ จะได้ไม่วนลูปซ้ำซ้อน
ด้วยคำสั่ง doEvent (interuption)


ประวัติการแก้ไข
2017-11-17 00:07:43
2017-11-17 08:12:34
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2017-11-17 00:01:31 By : Chaidhanan
 


 

No. 7



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



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

ตอบความคิดเห็นที่ : 6 เขียนโดย : Chaidhanan เมื่อวันที่ 2017-11-17 00:01:31
รายละเอียดของการตอบ ::
ขอบคุณครับ ตอนนี้ผมก็ใช้วิธีการ Load Data เข้ามาไว้ใน ตัวแปล DataSet ก่อนครับ แล้วค่อยให้ Event_KeyDown เข้าไปค้นหาข้อมูลใน DataSet ครับ แต่ก็มีความรู้สึกมันหนึด ๆ อยู่ครับ อยากจะขอตัวอย่าง Code ที่มีการหน่วงเวลามาใช้และการดึงข้อมูล ทีละ 10 Record เข้ามาที ครับ ขอบคุณครับ

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2017-11-23 14:52:25 By : stanly
 

   

ค้นหาข้อมูล


   
 

แสดงความคิดเห็น
Re : สอบถามขอความช่วยเหลือครับ ปัญหาการค้นหาข้อมูลออกมาแสดงช้ามากครับ เงื่อนไขอยากได้แบบ AutoComplete ภาษา C# ครับ
 
 
รายละเอียด
 
ตัวหนา ตัวเอียง ตัวขีดเส้นใต้ ตัวมีขีดกลาง| ตัวเรืองแสง ตัวมีเงา ตัวอักษรวิ่ง| จัดย่อหน้าอิสระ จัดย่อหน้าชิดซ้าย จัดย่อหน้ากึ่งกลาง จัดย่อหน้าชิดขวา| เส้นขวาง| ขนาดตัวอักษร แบบตัวอักษร
ใส่แฟลช ใส่รูป ใส่ไฮเปอร์ลิ้งค์ ใส่อีเมล์ ใส่ลิ้งค์ 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 05
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 อัตราราคา คลิกที่นี่