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

HOME > .NET Framework > Forum > Sql Server คำสั่ง select ที่เงื่อนไขในการเปรียบเทียบมีความยาวมากๆ



 

Sql Server คำสั่ง select ที่เงื่อนไขในการเปรียบเทียบมีความยาวมากๆ

 



Topic : 099343



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

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

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




ผมมี table เก็บข้อมูลรายละเีอียดของหนังสือ table นี้ ผมใช้หลักการว่า ถ้าข้อมูลใน field มีการเปลี่ยนแปลง ให้ทำการ mark ที่ record นั้นว่า เป็น unused แล้วทำการเพิ่ม record ใหม่ที่ข้อมูลเปลี่ยนแปลงไป ทำนองว่าคล้ายๆ เป็นการเก็บ log ไปในตัว


ทีนี้อยากจะถามว่า ถ้าข้อมูลใน field มีความยาวมากๆ เช่น ข้อมูลสรุปเนื้อหาหนังสือ มีตัวอักษรประมาณ 200-500 ตัว เช่น

sumValue = "เชื่อหรือไม่ว่า... อาหารที่เราเลือกกิน ชอบกิน หรือนิยมกินนั้น ได้รับอิทธิพลจากสังคม เศรษฐกิจ และการเมืองภายในประเทศ รวมทั้งต่างประเทศมากอย่างที่เราคิดไม่ถึง! ความนิยม อาหารไทยในต่างแดน อาทิ ต้มยำกุ้ง และผัดไทย เกี่ยวข้องกับการทำนากุ้งและการส่งออกไปขายในต่างประเทศ ความนิยมกินเนื้อวัวและขนมหวาน ถูกกำหนดโดยผลประโยชน์ของอุตสาหกรรมเนื้อวัวและน้ำตาลที่มีมาแต่ครั้งอดีตและต่อเนื่องถึงปัจจุบัน อาหารธรรมชาติที่ดีกับสุขภาพไม่ได้รับการโปรโมต ขณะที่ปัจจุบันพวกเรากำลังกินอาหารหลายอย่างที่ทำลายสุขภาพ เหตุใดจึงเป็นเช่นนั้น? ยังมีอาหารชนิดใดอีกบ้างที่โลกาภิวัตน์และการเปลี่ยนแปลงของกระแสโลก มีอิทธิพลกำหนดวัฒนธรรมในการเลือกอาหารของเรา? หนังสือเล่มนี้จะพาคุณไปพบกับเรื่องราวเบื้องลึกเบื้องหลังของ อาหาร วัฒนธรรม และสุขภาพ ที่เกี่ยวข้อกันอย่างแนบแน่นจนคุณอาจคาดไม่ถึง!"

ผมกะว่าจะใช้คำสั่ง select field_summary from table_book where field_summary = sumValue;

ถ้าหากว่า คืนค่ามาเป็น 0 row หมายความว่า field_summary นั้นมีการเปลี่ยนแปลง ก็สั่งให้ insert ข้อมูลที่เปลี่ยนแปลงลงไป
แต่ถ้าหากคืนค่าเป็น 1 row แสดงว่าค่าเดิมไม่เปลี่ยนแปลง ไม่ต้อง insert row ใหม่

ทำอย่างนี้จะหนัก sql server เกินไปหรือไม่ครับ

user ไม่มาก update ข้อมูลพร้อมๆ กันประมาณ 10 คนครับ

ขอบคุณครับ



Tag : .NET, Ms SQL Server 2008, C#







Move To Hilight (Stock) 
Send To Friend.Bookmark.
Date : 2013-08-20 13:26:06 By : Aod47 View : 1208 Reply : 7
 

 

No. 1

Guest


ผมไม่ใช่นักวิเคราะห์ระบบ (SA) อันนี้เป็นแนวคิดแบบบ้านบ้าน บ้าบ้าบอบอ ของผม

ออกแบบตาราง (Table) และให้ความสำคัญกับดัชนี (Index) และ เล่นกับดัชนี (Index)
และยกเลิก แนวคิด unused

เมื่อมีการเปลี่ยนแปลง

Update BookMaster Set field_summary = 'sumValue', Revision = Revision + 1 Where BookID = ?
Insert Into BookLog (BookID, field_summary, CreatedBy) Values (?, 'sumValue (ยาว)', 'Dang')

เมื่อต้องการดูประวัติการแก้ไขล่า่สุด (โดยไม่ต้องใช้ Order By)

Select TOP 1 * From BookLog Where BookID = ?


โครงสร้างตาราง BookMaster
BookID (int) field_summary (varchar(MAX)) Revision (int) Primary Key : BookID (Asc) + Revision (Asc)


ข้อมูลตัวอย่างตาราง BookMaster
BookID field_summary Revision 1 aaaaaaaa (ยาว) 0 2 bbbbbbbb (ยาว) 9 3 ccccccccc (ยาว) 100 ...


โครงสร้างตาราง BookLog
BookID (int) field_summary (varchar(MAX)) ListNo(int) Identity = yes , Identity seed = 1 CreatedBy (varchar) Primary Key : BookID (Asc) + ListNo(Desc)


ข้อมูลตัวอย่างตาราง BookLog
BookID field_summary ListNo CreatedBy 1 aaaaaaaX (ยาว) 100 Dang 1 aaaaaaaY (ยาว) 99 Dam 1 aaaaaaaZ (ยาว) 98 Dong 1 aaaaaaaU (ยาว) 97 Dog ...







แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2013-08-21 20:12:33 By : ผ่านมา
 


 

No. 2

Guest


#NO 1 แก้ไขโครงสร้างตาราง BookMaster
จาก Primary Key : BookID (Asc) + Revision (Asc)
เป็น Primary Key : BookID (Asc)

ทำไมไม่ทำดัชนี (Index) Columns field_summary ???
Full Text Search คือคำตอบ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2013-08-21 20:25:51 By : ผ่านมา
 

 

No. 3



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



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

ตอบความคิดเห็นที่ : 1 เขียนโดย : ผ่านมา เมื่อวันที่ 2013-08-21 20:12:33
รายละเอียดของการตอบ ::
วิเคราะห์ได้ดีครับ ควรจะทำอย่างนี้เลย

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2013-08-21 20:28:59 By : 01000010
 


 

No. 4



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

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

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


แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2013-08-22 06:12:35 By : mr.win
 


 

No. 5

Guest


Quote:
ทำอย่างนี้จะหนัก sql server เกินไปหรือไม่ครับ


ผมแสดงความคิดเห็นให้ตรงประเด็น "ถ้าเป็น Client/Server ถ้าทำแบบนี้ ผมคิดว่าไม่มีผลกระทบ"
แต่ถ้าสงสัยว่า "เหมาะสมหรือไม่" ผมไม่แน่ใจ มันต้องแยกเป็นกรณีฯไป อาจจะ/ไม่/เหมาะ ก็อาจเป็นไปได้ครับ

[x1] แต่ผมชอบแนวคิด/คำอธิบาย ปัญหาของเจ้าของกระทู้ (เยี่ยมยอดเลยทีเดียว)
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2013-08-22 09:41:34 By : ผ่านมา
 


 

No. 6



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

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

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


ขอบคุณครับ แต่ว่า แก้โครงสร้างไม่ได้แล้วครับ เอาไว้เป็นแนวคิด โปรเจ็กต์ ถัดไปครับ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2013-08-22 13:40:30 By : Aod47
 


 

No. 7



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

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

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


มา update ผลการทดลองกับ user เพียง 1 คนครับ

ผลก็คือ พอสั่ง save change ด้วยค่า summary ค่าใหม่ เร็วมากครับ 1 วินาทีเสร็จ

ไม่ได้จับเวลานะครับ แต่ผมทำเป็น pop up ขึ้นมาให้ดูว่า มีข้อมูลอะไรที่ส่งไป save ที่ server

ซึ่ง pop up นี้จะแสดงผลก็ต่อเมื่อ ดำเนินการกับทุก record เสร็จหมดแล้ว

พอกดปุ่ม save ปุ๊บ pop up เด้งขึ้นมาทันทีครับ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2013-08-23 15:39:22 By : Aod47
 

   

ค้นหาข้อมูล


   
 

แสดงความคิดเห็น
Re : Sql Server คำสั่ง select ที่เงื่อนไขในการเปรียบเทียบมีความยาวมากๆ
 
 
รายละเอียด
 
ตัวหนา ตัวเอียง ตัวขีดเส้นใต้ ตัวมีขีดกลาง| ตัวเรืองแสง ตัวมีเงา ตัวอักษรวิ่ง| จัดย่อหน้าอิสระ จัดย่อหน้าชิดซ้าย จัดย่อหน้ากึ่งกลาง จัดย่อหน้าชิดขวา| เส้นขวาง| ขนาดตัวอักษร แบบตัวอักษร
ใส่แฟลช ใส่รูป ใส่ไฮเปอร์ลิ้งค์ ใส่อีเมล์ ใส่ลิ้งค์ 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 00
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 อัตราราคา คลิกที่นี่