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

HOME > .NET Framework > Forum > อยากรู้วิธีการจัดการกับฐานข้อมูล เพื่อไม่ให้เก็บประวัติข้อมูลเยอะในtable ควรทำอย่างไรดี



 

อยากรู้วิธีการจัดการกับฐานข้อมูล เพื่อไม่ให้เก็บประวัติข้อมูลเยอะในtable ควรทำอย่างไรดี

 



Topic : 119346



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



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




โดยมี tableaddสินค้า,tableเบิกสินค้า และquerystock

1.tableaddสินค้า มีคอลัม ลำดับที่,ว/ด/ป,ชื่อสินค้า,จำนวนที่add
2.tableเบิกสินค้า มีคอลัม ลำดับที่,ว/ด/ป,ชื่อสินค้า,จำนวนที่เบิก
3.querystock มีคอลัม สินค้า,จำนวนที่add,จำนวนที่เบิก,จำนวนคงเหลือ
โดยคอลัม จำนวนที่add ได้จากtableaddสินค้า
จำนวนที่เบิก ได้จากtableเบิกสินค้า
จำนวนคงเหลือ ได้จาก จำนวนที่add - จำนวนที่เบิก
ดังนี้
สินค้า จำนวนที่add จำนวนที่เบิก จำนวนคงเหลือ
ตะปู 100 1 99
เข็ม 100 2 98
น็อต 100 3 97

*****ซึ่งปัญหาตอนนี้คือต้องเก็บประวัติข้อมูลของtableทั้ง2ไปเรื่อยๆ ถ้าไม่ยังงั้น ค่าจำนวนที่add , จำนวนที่เบิก , จำนวนคงเหลือ ก็จะได้ค่าไม่เป็นปัจจุบันดังข้างต้น
เช่น ถ้าลบประวัติในtableเบิกสินค้าออกไป จะทำให้querystock เป็นดังนี้
สินค้า จำนวนที่add จำนวนที่เบิก จำนวนคงเหลือ
ตะปู 100 0 100
เข็ม 100 0 100
น็อต 100 0 100

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



Tag : .NET, Ms Access, VB.NET, VS 2012 (.NET 4.x)







Move To Hilight (Stock) 
Send To Friend.Bookmark.
Date : 2015-10-12 17:09:28 By : peemes101 View : 991 Reply : 12
 

 

No. 1



โพสกระทู้ ( 4,440 )
บทความ ( 23 )



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

Index and PK บ้านๆๆเลย






แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-10-12 20:42:09 By : lamaka.tor
 


 

No. 2



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



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


ที่คุณTOR_CHEMISTRY บอกว่าIndex and PK
มันสามารถแก้ปัญหานี้ได้
*****ซึ่งปัญหาตอนนี้คือต้องเก็บประวัติข้อมูลของtableทั้ง2ไปเรื่อยๆ ถ้าไม่ยังงั้น ค่าจำนวนที่add , จำนวนที่เบิก , จำนวนคงเหลือ ก็จะได้ค่าไม่เป็นปัจจุบันดังข้างต้น
เช่น ถ้าลบประวัติในtableเบิกสินค้าออกไป จะทำให้querystock เป็นดังนี้
สินค้า จำนวนที่add จำนวนที่เบิก จำนวนคงเหลือ
ตะปู 100 0 100
เข็ม 100 0 100
น็อต 100 0 100


ช่วยอธิบายให้มากกว่านี้ได้หรือป่าว
หรือพอมีตัวอย่างมั้ย
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-10-12 23:05:01 By : peemes101
 

 

No. 3



โพสกระทู้ ( 4,440 )
บทความ ( 23 )



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

ถ้าจะออกแบบ store ให้ลองนึกถึงพวกร้านใหญ่ๆดูครับ

7-11 lotus bigc makro ฯลฯ

ลองเข้าเว็บเขาแล้วเอามาประยุค ใช้

สิ่งที่ท่านขาดไปคือ table สินค้า
ถึงจะเรียกได้ว่าใช้ Index and PK ได้เหมาะสม

tableaddสินค้า tableเบิกสินค้า ก็แต่ดึง PK ออกมาใช้

แค่นี้ database ก็ไม่รก กลายเป็นขยะ database ไปแล้วครับ

ที่เหลือก็แค่ อ่านเรื่อง join
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-10-13 09:25:10 By : lamaka.tor
 


 

No. 4



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



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


tableสินค้า มีอยู่แล้ว

ที่คุณบอกว่า tableaddสินค้า tableเบิกสินค้า ก็แค่ดึง PK ออกมาใช้
นี้ใช่สร้างqueryของaddสินค้า และqueryของเบิกสินค้า
แต่PKที่กำหนดไว้ก็มีแค่คอลัม ลำดับที่ ที่กำหนดเป็นPKไว้เอง
แล้วถ้าไม่ใช่ มันต้องทำอย่างไร



และเรื่องdatabase ก็ไม่รก กลายเป็นขยะ database ไปแล้ว
แสดงว่า จะสามารถลบประวัติในtable หรือลบrecord ได้ใช่หรือป่าว


ส่วนเรื่องjoin ควรสร้างอย่างไร
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-10-13 16:20:42 By : peemes101
 


 

No. 5



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



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


เรื่องนี้คงต้องไปดูในหัวข้อ Normalization ครับ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-10-13 17:04:10 By : fonfire
 


 

No. 6



โพสกระทู้ ( 4,440 )
บทความ ( 23 )



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

ตอบความคิดเห็นที่ : 4 เขียนโดย : peemes101 เมื่อวันที่ 2015-10-13 16:20:42
รายละเอียดของการตอบ ::

กล่าวกันว่า

ตะปู 100 0 100
เข็ม 100 0 100
น็อต 100 0 100

ไม่ถือว่าเป็นการใช้งาน Index and PK ได้เหมาะสม

รุปแบบที่ถูกคือ

001 100 0 100
002 100 0 100
003 100 0 100


ลองนึกถึงว่ามี User คนหนึ่ง เขียนผิดจาก ตะปู เป็น ตาปู ตำปู ตะ ปู ดู เวลา query ออกมา มันก็จะแยกกัน
นี่แค่ 2คำ แต่ถ้าเป็น ตะปูเข็มหมุดดอกใหญ่ จะเป็นยังไง

ส่วนเรื่อง join ถ้าจัด table ดีๆ ศึกษาเรื่อง Normalization ตามที่ท่าน fonfire กล่าวมา
การ join ก้เป็นเรื่อง บ้านๆ ไปเลยครับ(ย้ำถ้าจัด table ดีๆ )

https://www.thaicreate.com/community/csharp-add-datatable-in-wizard-ban-ban.html

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-10-13 18:34:44 By : lamaka.tor
 


 

No. 7



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



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


ได้แก้โดยใช้combobox ให้เลือก
เพราะถ้าเป็นตัวเลข user อาจจะไม่รู้ เอ๊ะ มันคืออะไร

ได้ดูเรื่อง Normalization แล้วก็ประมาณว่า ควรสร้างtableอย่างไร ให้ไม่ซับซ้อน
โดยตอนนี้มี
tableสินค้า
tableประเภท
tableaddสินค้า
tableเบิกสินค้า


สรุปคือแล้วมันสามารถไปแก้ปัญหาดังนี้ ได้อย่างไร

*****ซึ่งปัญหาตอนนี้คือต้องเก็บประวัติข้อมูลของtableทั้ง2ไปเรื่อยๆ ถ้าไม่ยังงั้น ค่าจำนวนที่add , จำนวนที่เบิก , จำนวนคงเหลือ ก็จะได้ค่าไม่เป็นปัจจุบันดังนี้
ุซึ่งถ้ามีการเบิกสินค้าดังนี้
สินค้า จำนวนที่add จำนวนที่เบิก จำนวนคงเหลือ
ตะปู 100 1 99
เข็ม 100 2 98
น็อต 100 3 97

และถ้าลบประวัติในtableเบิกสินค้าออกไป จะทำให้querystock เป็นดังนี้

สินค้า จำนวนที่add จำนวนที่เบิก จำนวนคงเหลือ
ตะปู 100 0 100
เข็ม 100 0 100
น็อต 100 0 100
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-10-14 03:19:09 By : peemes101
 


 

No. 8



โพสกระทู้ ( 4,440 )
บทความ ( 23 )



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


แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-10-14 07:39:37 By : lamaka.tor
 


 

No. 9



โพสกระทู้ ( 4,440 )
บทความ ( 23 )



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

https://www.thaicreate.com/community/csharp-datasource-wizard-datagridviewcomboboxcolumn.html
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-10-14 08:00:58 By : lamaka.tor
 


 

No. 10

Guest


แสดงว่ายังไม่เข้าใจเรื่อง Normalization (ผมก็ไม่เข้าใจ) แต่อยากให้ศึกษาเรื่องนี้ให้ดีและให้แน่นก่อนที่จะสงสัยว่ามันดีหรือไม่ดี
มันจัดการกับข้อมูลได้แค่ไหน แต่เราเองก็ควรที่จะเข้าใจระบบให้ดีก่อน ไม่ใช่อยู่ดีๆใครก็ได้จะไปลบเทเบิลทิ้งซึ่งมันเป็นไปไม่ได้
เลย ไม่ว่าระบบจะดีแค่ไหน ใหญ่แค่ไหน และการลบเทเบิลหรือข้อมูลเป็นงานที่ไม่ฉลาดเอาเลย(ควรแค่เปลี่ยนสถานะก็พอ)
และอีกอย่างนะครับ ถ้ายังไม่ขึ้นระบบหรือแค่ศึกษาขอแนะนำว่าให้เอา
tableaddสินค้า
tableเบิกสินค้า
ออกไปเลยครับ แล้วเปลี่ยนมาใช้เทเบิลกลางที่จะเก็บทั้งเข้าและออกดีกว่าครับโดยแทนค่า + - ประเภทเอา

หรือจะดูตัวอย่างของระบบ ERP infor syteline นี้ก็ได้ครับ(ยกมานิดเดียว ที่จริงมันเยอะกว่านี้ครับ)

เทเบิล item
item
descriptions
product_code
u_m
...

เทเบิล matltran (จะรับเข้า,เบิก,ทิ้ง,ย้าย) ประวัติจะเก็บอยู่เทเบิลนี้หมดครับ
trans_num
trans_type (แยกตาม code)
trans_date
item
qty (+ = รับ เพิ่ม ,- = จ่าย ทิ้ง)
ref_num(เลขที่ใบเบิก,เลขที่ po,...)

ดูยอดคงเหลือเฉยๆ ก็ sum qty ที่เทเบิล matltran ไปเลย


และอีกอย่างที่ระบบใหญ่ๆเขาใช้กัน คือเขาจะสร้าง View และ Stored Procedures Functions Tiger
เอาไว้ใช้งานเรื่อง select insert update delete เพราะสามารถทำ TRANSACTION ได้

"การออกแบบฐานข้อมูลเป็นเรื่องหลักของการเขียนโปรแกรม!"

ถ้าคำแนะนำผิดพลาดประการใด ก็ขออภัยเดียวนะครับผม อย่าว่ากันนะ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-10-14 20:03:10 By : บัญดิษฐ
 


 

No. 11



โพสกระทู้ ( 4,440 )
บทความ ( 23 )



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

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

ถือว่าเป็นคำที่สุดยอดครับ
ซึ่งมือใหม่หลายคนยังไม่ตระหนักถึงความสำคัญของการมีมันอยู่

และที่หนักไปกว่านั้น
หลายคนไม่ออกแบบ หรือ ศึกษาเรื่องการออกแบบฐานข้อมูลให้ดีแล้วก็นำฐานข้อมูลที่ออกแบบมาไม่ดีนั้นมาเขียน
ผลปรากฎว่า ต้องศึกษา เรื่อง SQL syntex มากขึ้น และ ได้รูปแบบการเขียนโปรแกรมแบบผิดๆตามมาด้วย

กว่าจะรู้ตัวก็จบ และ ทำงาน เรียบร้อยแล้ว
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-10-15 08:31:23 By : lamaka.tor
 


 

No. 12

Guest


ตอบความคิดเห็นที่ : 10 เขียนโดย : บัญดิษฐ เมื่อวันที่ 2015-10-14 20:03:10
รายละเอียดของการตอบ ::
ต่อ จะได้เห็นภาพ

matl


แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-10-15 08:52:55 By : บัญดิษฐ
 

   

ค้นหาข้อมูล


   
 

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