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 > สอบถามครับ เกี่ยวกับระบบเช่า-คืนหนังสือ หน้าคืนหนังสือ [Vb.Net + MySQL]



 

สอบถามครับ เกี่ยวกับระบบเช่า-คืนหนังสือ หน้าคืนหนังสือ [Vb.Net + MySQL]

 



Topic : 119803



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



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




ผมทำโปรเจคจบ ระบบเช่า-คืน หนังสือเป็น WinApp ด้วย VB.Net ใช้ฐานข้อมูล MySQL ตอนนี้ติดปัญหาตรงหน้าคืนหนังสือน่ะครับ คือถ้าอยากจะให้มีการคิดค่าปรับด้วยในกรณีที่เกินเวลาที่กำหนด เราจะต้องทำยังไงหรอครับ



Tag : .NET, MySQL, Win (Windows App), VB.NET, VS 2012 (.NET 4.x)







Move To Hilight (Stock) 
Send To Friend.Bookmark.
Date : 2015-11-09 15:11:37 By : Jamesillion View : 2281 Reply : 17
 

 

No. 1



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

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

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

ใช้ DateDiff หาวันที่เกิน แล้วไป x ค่าปรับต่อวันได้เลยครับ

Code (VB.NET)
Dim datTim1 As Date = #1/4/2001#
Dim datTim2 As Date = #1/9/2001#
' Assume Sunday is specified as first day of the week. 
Dim wD As Long = DateDiff(DateInterval.Weekday, datTim1, datTim2)
Dim wY As Long = DateDiff(DateInterval.WeekOfYear, datTim1, datTim2)







แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-11-09 15:58:15 By : mr.win
 


 

No. 2



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



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


ตอบความคิดเห็นที่ : 1 เขียนโดย : mr.win เมื่อวันที่ 2015-11-09 15:58:15
รายละเอียดของการตอบ ::
ขอบคุณครับ แล้วถ้าต้องการหาจากตารางใน datagridview ต้องทำแบบไหนครับ

l

ตามภาพอยากจะเอาวันที่คืน - วันที่กำหนดคืน แล้วมาแสดงตรง วันที่เกิน ครับ ขอคำแนะนำด้วยครับ



ประวัติการแก้ไข
2015-11-10 01:52:55
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-11-10 01:51:28 By : Jamesillion
 

 

No. 3



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

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

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


ถ้าในตารางคุณมีช่อง กำหนดคืน กับ วันที่คืนแล้ว ใช้คำสั่งหรือฟังก์ชั่น ของ MySql หาออกมาก็ได้นี่ครับ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-11-10 07:24:16 By : Aod47
 


 

No. 4



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



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

ตอบความคิดเห็นที่ : 2 เขียนโดย : Jamesillion เมื่อวันที่ 2015-11-10 01:51:28
รายละเอียดของการตอบ ::
ทำให้เป็น datetime แล้วลบแบบบ้านๆก็น่าจะได้แระครับ

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-11-10 08:17:35 By : lamaka.tor
 


 

No. 5



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



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


ตอบความคิดเห็นที่ : 3 เขียนโดย : Aod47 เมื่อวันที่ 2015-11-10 07:24:16
รายละเอียดของการตอบ ::
ใน database มันยังไม่ได้บันทึกข้อมูลของ วันที่คืน ลงไปน่ะครับ ผมเพียงแต่ใช้การเรียกข้อมูลจาก Tmp มาใช้แสดงชั่วคราวก่อนการบันทึกน่ะครับ ทีนี้เลยไม่รู้วิธีการเรียกออกมาแสดงพร้อมกับการคิดวันที่คืน และ ค่าปรับ น่ะครับ

Code (VB.NET)
Private Sub DataGridView1_CellMouseDoubleClick(sender As Object, e As DataGridViewCellMouseEventArgs) Handles DataGridView1.CellMouseDoubleClick

        Dim i As Integer
        i = DataGridView1.CurrentRow.Index
        Dim B_ID As Integer

        B_ID = Convert.ToUInt32(DataGridView1.Item(1, i).Value) 
        StrSQL = "INSERT INTO renttmp1(Barcode_ID,DateOver)VALUES(" & B_ID & ", NOW())"
        ds = New DataSet
        da = New MySqlDataAdapter(StrSQL, MySQLConn)
        da.Fill(ds, "renttmp1")

        Call UpdateOverDays()
        'MsgBox("Insert complete!")
        MySQLConn.Close()

        Me.Close()
    End Sub

    Sub UpdateOverDays()
        StrSQL = "UPDATE renttmp1 SET OverDays = DATEDIFF(now(),DateOver) WHERE ID"
        ds = New DataSet
        da = New MySqlDataAdapter(StrSQL, MySQLConn)
        da.Fill(ds, "renttmp1")

    End Sub


แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-11-10 16:02:59 By : Jamesillion
 


 

No. 6



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



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


ตอบความคิดเห็นที่ : 4 เขียนโดย : lamaka.tor เมื่อวันที่ 2015-11-10 08:17:35
รายละเอียดของการตอบ ::
ตอนนี้ใน database ไม่มีข้อมูลของ วันที่คืน ครับ ในรูปผมแค่บันทึกลง Tmp แล้วดึงมาโชว์ก่อนการบันทึก เลยอยากจะทราบวิธีการดังมาโชว์แล้ว คิดวันที่คืน วันที่เกิน ค่าปรับ/เล่ม น่ะครับ

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-11-10 16:05:05 By : Jamesillion
 


 

No. 7



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



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

ตอบความคิดเห็นที่ : 6 เขียนโดย : Jamesillion เมื่อวันที่ 2015-11-10 16:05:05
รายละเอียดของการตอบ ::

ดึงจาก datagrid ครับ

ทำให้เป็น datetime แล้วลบแบบบ้านๆก็น่าจะได้แระครับ



แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-11-10 16:47:00 By : lamaka.tor
 


 

No. 8



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

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

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


สร้าง query join ตารางที่ใช้เก็บข้อมูลยืม กับ ตาราง renttemp1

คุณน่าจะมีข้อมูลเหล่านี้อยู่นะ ID ผู้ยืม ID หนังสือ

Grid ก็เปลี่ยนมาเรียกข้อมูลจาก query นี้แทน
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-11-11 11:39:27 By : Aod47
 


 

No. 9



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



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


ตอบความคิดเห็นที่ : 8 เขียนโดย : Aod47 เมื่อวันที่ 2015-11-11 11:39:27
รายละเอียดของการตอบ ::
ขอบคุณครับ พอจะมีวิธีบันทึกข้อมูลประเภท date ลงฐานข้อมูลมั้ยครับ พอดีดึงข้อมูลจากตาราง rent มาแล้วจะบันทึกลง renttemp1 แต่มันขึ้นเป็น 0000-00-00 ครับ

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-11-11 14:32:26 By : Jamesillion
 


 

No. 10



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



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

ต้องดูที่โค้ดครับว่า Insert/Update ถูกต้องไม๊ ถ้าถูกก็ไม่น่ามีตัณหาครับ

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


 

No. 11



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



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


ตอบความคิดเห็นที่ : 10 เขียนโดย : lamaka.tor เมื่อวันที่ 2015-11-11 14:55:15
รายละเอียดของการตอบ ::
ช่วยดูให้หน่อยครับ ผมลองเขียนแบบนี้ดู
สส

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-11-11 14:58:50 By : Jamesillion
 


 

No. 12



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



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


Code (VB.NET)
'debug ค่าตรงนี้ดูก่อนครับ ว่าใช่ตัวแปรวันที่หรือเปล่า ?
DataGridView1.Item(8,i).Value

'ถ้าใช่ ก็แปลงเป็นวันที่ด้วยคำสั่ง Cdate และเก็บค่าไว้ที่ตัวแปร D_ID ที่ได้ประกาศไว้
D_ID = Cdate(DataGridView1.Item(8,i).Value)


อย่าลืมว่าคำสั่ง ToString คือเปลี่ยนให้เป็นตัวแปรประเภทสตริงนะครับ
พอ Date.Parse มาเจอสตริงที่ไม่ตรงกับรูปแบบวันที่จะแปลงไม่ได้แล้วเกิดเออเร่อขึ้น
ดังนั้นก่อนจะทำ ก็ควรจะตรวจสอบค่าของตัวแปรที่เราจะแปลงค่าก่อนครับ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-11-11 22:41:46 By : deksoke
 


 

No. 13



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



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


ตอบความคิดเห็นที่ : 12 เขียนโดย : deksoke เมื่อวันที่ 2015-11-11 22:41:46
รายละเอียดของการตอบ ::
ใช่ครับเป็น date ลองแก้โค้ดเป็น
Code (VB.NET)
 Dim i As Integer
        i = DataGridView1.CurrentRow.Index
        Dim B_ID As Integer
        Dim D_ID As Date

        B_ID = Convert.ToUInt32(DataGridView1.Item(1, i).Value)
        D_ID = CDate(DataGridView1.Item(8, i).Value)
        StrSQL = "INSERT INTO renttmp1(Barcode_ID,DateEnd,DateOver)VALUES(" & B_ID & "," & D_ID & ", Now())"
        ds = New DataSet
        da = New MySqlDataAdapter(StrSQL, MySQLConn)
        da.Fill(ds, "renttmp1")


มันลงนะครับ แต่มันกลับเป็น 0000-00-00 ครับ พอมีวิธีให้ค่าลงไปตามจริงมั้ยครับ แก้มาเป็นวันแล้วยังไม่ได้เลย ขอคำแนะนำด้วยครับมือใหม่หัดเขียนจริงๆ

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-11-11 22:48:56 By : Jamesillion
 


 

No. 14



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



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

ลอง alert. มาดูได้ครับว่าใช่ค่าที่เราต้องการป่าว
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-11-12 01:06:02 By : lamaka.tor
 


 

No. 15



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



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


ตอบความคิดเห็นที่ : 14 เขียนโดย : lamaka.tor เมื่อวันที่ 2015-11-12 01:06:02
รายละเอียดของการตอบ ::
alert ยังไงหรอครับ

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-11-12 02:12:44 By : Jamesillion
 


 

No. 16



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



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

ตอบความคิดเห็นที่ : 15 เขียนโดย : Jamesillion เมื่อวันที่ 2015-11-12 02:12:44
รายละเอียดของการตอบ ::
MessageBox.Show(StrSQL)
http://www.dotnetperls.com/messagebox-show-vbnet



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


 

No. 17



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

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

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


ผมไม่รู้ว่า MySql เวลา Insert field จำพวก date, datetime ใช้รูปแบบเหมือน MS Sql Server หรือเปล่า

สำหรับ Sql Server เวลา Insert ใช้แบบนี้ก็ได้ DateEnd='2015/11/30'

ถ้าเป็น Oracle ต้องแปลงเป็นแบบนี้ DateEnd=to_date('30-11-2015','DD-MM-YYYY')

ลองตรวจดูก่อนครับว่า MySql ใช้รูปแบบไหน


หรือไม่อย่างนั้น ลองใช้เป็น parameter ส่งค่าเข้าไป จะลดโอกาสการผิดพลาดจากการต่อ string

ตัวอย่าง เช่น

DateTime dateEnd = DateTime.Now;
SqlParameter param = new SqlParameter();
param = objInsert.Parameters.AddWithValue("@DateEnd", dateEnd);


ประวัติการแก้ไข
2015-11-12 10:24:30
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-11-12 10:20:11 By : Aod47
 

   

ค้นหาข้อมูล


   
 

แสดงความคิดเห็น
Re : สอบถามครับ เกี่ยวกับระบบเช่า-คืนหนังสือ หน้าคืนหนังสือ [Vb.Net + MySQL]
 
 
รายละเอียด
 
ตัวหนา ตัวเอียง ตัวขีดเส้นใต้ ตัวมีขีดกลาง| ตัวเรืองแสง ตัวมีเงา ตัวอักษรวิ่ง| จัดย่อหน้าอิสระ จัดย่อหน้าชิดซ้าย จัดย่อหน้ากึ่งกลาง จัดย่อหน้าชิดขวา| เส้นขวาง| ขนาดตัวอักษร แบบตัวอักษร
ใส่แฟลช ใส่รูป ใส่ไฮเปอร์ลิ้งค์ ใส่อีเมล์ ใส่ลิ้งค์ 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 01
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 อัตราราคา คลิกที่นี่